当前位置: 首页 > news >正文

POI与EasyExcel--写Excel

简单写入

 03和07版的简单写入注意事项:

1. 对象不同:03对应HSSFWorkbook,07对应XSSFWorkbook

2. 文件后缀不同:03对应xls,07对应xlsx

package com.zrf;import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.xssf.streaming.SXSSFWorkbook;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
import org.joda.time.DateTime;
import org.junit.Test;import java.io.FileOutputStream;public class ExcelWriteTest {String PATH = "D:\\ideaprojection\\excel_test\\poi";@Testpublic void testWrite03() throws Exception {// 创建一个工作簿Workbook workbook = new HSSFWorkbook();// 创建一张工作表Sheet sheet = workbook.createSheet("统计表");// 创建第一行Row row1 = sheet.createRow(0);// 创建一个单元格Cell cell11 = row1.createCell(0);cell11.setCellValue("今日新增实习生");Cell cell12 = row1.createCell(1);cell12.setCellValue(1);// 创建第二行Row row2 = sheet.createRow(1);Cell cell21 = row2.createCell(0);cell21.setCellValue("统计时间");Cell cell22 = row2.createCell(1);String time = new DateTime().toString("yyyy-MM-dd HH:mm:ss");cell22.setCellValue(time);// 生成一张表(IO流)// 03版本就是使用xls结尾FileOutputStream fileOutputStream = new FileOutputStream(PATH + "统计表03.xls");// 输出workbook.write(fileOutputStream);// 关闭流fileOutputStream.close();System.out.println("统计表03版本生成完毕");}@Testpublic void testWrite07() throws Exception {// 创建一个工作簿Workbook workbook = new XSSFWorkbook();// 创建一张工作表Sheet sheet = workbook.createSheet("统计表");// 创建第一行Row row1 = sheet.createRow(0);// 创建一个单元格Cell cell11 = row1.createCell(0);cell11.setCellValue("今日新增实习生");Cell cell12 = row1.createCell(1);cell12.setCellValue(1);// 创建第二行Row row2 = sheet.createRow(1);Cell cell21 = row2.createCell(0);cell21.setCellValue("统计时间");Cell cell22 = row2.createCell(1);String time = new DateTime().toString("yyyy-MM-dd HH:mm:ss");cell22.setCellValue(time);// 生成一张表(IO流)// 03版本就是使用xls结尾FileOutputStream fileOutputStream = new FileOutputStream(PATH + "统计表07.xlsx");// 输出workbook.write(fileOutputStream);// 关闭流fileOutputStream.close();System.out.println("统计表07版本生成完毕");}}

数据批量导入

大文件写HSSF 

             缺点: 最多处理65536行,再多会抛出异常
             优点: 过程中写入缓存,不操作磁盘,最后一次性写入磁盘,速度快


大文件写XSSF 

            缺点: 写数据时速度非常慢,非常耗内存,也会发生内存溢出,如100万条
            优点: 可以写较大的数据量

SXSSF优化版本

            优点: 可以写非常大的数据量,如100万甚至更多条,写数据速度更快,占用更少的内存
            注意: 过程中会产生临时文件,需要清理临时文件
                       默认100条数据被保存到内存中,如果超过这数量,则最前面的数据被写入临时文件,如果想自定义内存中数据的数量,可以使用new SXSSFWorkbook(数量)

package com.zrf;import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.xssf.streaming.SXSSFWorkbook;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
import org.joda.time.DateTime;
import org.junit.Test;import java.io.FileOutputStream;public class ExcelWriteTest {String PATH = "D:\\ideaprojection\\excel_test\\poi";@Testpublic void testWrite03BigData() throws Exception {// 时间long begin = System.currentTimeMillis();// 创建一个工作簿Workbook workbook = new HSSFWorkbook();// 创建一张工作表Sheet sheet = workbook.createSheet("统计表");// 写入数据for (int rowNum = 0; rowNum < 65536; rowNum++){Row row = sheet.createRow(rowNum);for (int cellNum = 0; cellNum < 10; cellNum++){Cell cell = row.createCell(cellNum);cell.setCellValue(cellNum);}}System.out.println("over");FileOutputStream fileOutputStream = new FileOutputStream(PATH + "testWrite03BigData.xls");workbook.write(fileOutputStream);fileOutputStream.close();long end = System.currentTimeMillis();System.out.println((double) (end - begin)/1000);}// 耗时较长 优化 缓存@Testpublic void testWrite07BigData() throws Exception {// 时间long begin = System.currentTimeMillis();// 创建一个工作簿Workbook workbook = new XSSFWorkbook();// 创建一张工作表Sheet sheet = workbook.createSheet("统计表");// 写入数据for (int rowNum = 0; rowNum < 65537; rowNum++){Row row = sheet.createRow(rowNum);for (int cellNum = 0; cellNum < 10; cellNum++){Cell cell = row.createCell(cellNum);cell.setCellValue(cellNum);}}System.out.println("over");FileOutputStream fileOutputStream = new FileOutputStream(PATH + "testWrite07BigData.xlsx");workbook.write(fileOutputStream);fileOutputStream.close();long end = System.currentTimeMillis();System.out.println((double) (end - begin)/1000);}@Testpublic void testWrite07BigDataS() throws Exception {// 时间long begin = System.currentTimeMillis();// 创建一个工作簿Workbook workbook = new SXSSFWorkbook();// 创建一张工作表Sheet sheet = workbook.createSheet("统计表");// 写入数据for (int rowNum = 0; rowNum < 65537; rowNum++){Row row = sheet.createRow(rowNum);for (int cellNum = 0; cellNum < 10; cellNum++){Cell cell = row.createCell(cellNum);cell.setCellValue(cellNum);}}System.out.println("over");FileOutputStream fileOutputStream = new FileOutputStream(PATH + "testWrite07BigDataS.xlsx");workbook.write(fileOutputStream);fileOutputStream.close();// 清除临时文件((SXSSFWorkbook) workbook).dispose();long end = System.currentTimeMillis();System.out.println((double) (end - begin)/1000);}}

http://www.lryc.cn/news/133324.html

相关文章:

  • 7. CSS(四)
  • uni-app 集成推送
  • Spring Boot+Redis 实现消息队列实践示例
  • 11. 实现业务功能--获取用户信息
  • HTTPS
  • spring详解
  • 香港服务器备案会通过吗?
  • 乐鑫推出 ESP ZeroCode 控制台
  • 从NLP到聊天机器人
  • 相关搜索引擎常用搜索语法(Google hacking语法和FOFA语法)
  • Mysql查询
  • 解决http下navigator.clipboard为undefined问题
  • mysql之host is blocked问题
  • 每日一题:2337 移动片段得到字符串
  • 嵌入式设备的 Json 库基本使用
  • GEEMAP 中如何拉伸图像
  • 软件测试学术顶会——ISSTA 2023 论文(网络安全方向)清单、摘要与总结
  • 基于YOLOv8模型和PCB电子线路板缺陷目标检测系统(PyTorch+Pyside6+YOLOv8模型)
  • centos安装mysql8
  • 【Apollo】阿波罗自动驾驶技术:引领汽车行业革新
  • 一文看懂!数据管道和数据流在数据分析中的作用
  • Linux系统下检验Tensorflow 2.xx版本和1.xx版本是否安装成功
  • 暑期高铁站大量遗失物品,FindMy帮助寻找
  • 通过安全日志读取WFP防火墙放行日志
  • JDK、JRE、Java SE、Java EE和Java ME有什么区别?
  • Neo4j之unwind基础
  • 回归预测 | MATLAB实现SSA-SVM麻雀搜索算法优化支持向量机多输入单输出回归预测(多指标,多图)
  • 深入探索代理技术:Socks5、IP代理与网络安全
  • Matlab 频谱图中如何设置频率刻度
  • 在线转换器有哪些优势?在线Word转PDF操作分享