网站首页 > 博客文章 正文
在之前我们知道处理xls的excel用的workbook是HSSFWorkbook,处理xlsx的excel用的是XSSFWorkbook。
1、SXSSFWorkbook是在POI3.8版本开始提供基于XSSF低内存占用的SXSSF
SXSSF通过一个滑动窗口来限制访问Row的数量从而达到低内存占用的目录,XSSF可以访问所有行。SXSSF通过设置rowAccessWindowSize的大小实现滑动窗口中存储数据量的row数量,当行数超过滑动窗口设定的值时,此时旧的数据不再出现在滑动窗口且不可对此进行
访问,同时将此数据写入磁盘。也可通过flushRow(int keepRows)设定行数通过周期性的调用来修改。
注意:针对 SXSSF Beta 3.8下,会有临时文件产生,比如:
poi-sxssf-sheet4654655121378979321.xml
文件位置:java.io.tmpdir这个环境变量下的位置
Windows 7下是C:UsersxxxxxAppDataLocalTemp
Linux下是 /var/tmp/
2、当数据量超出65536条后,在使用HSSFWorkbook或XSSFWorkbook,程序会报OutOfMemoryError:Javaheap space;内存溢出错误。这时应该用SXSSFworkbook
3.SXFFSWoorkbook导出的excel相比于XSSFWoorkbook导出的更节省空间:
4.测试HSSF\XSSF导出的数据占用内存,而SXFFS导出的数据不容易造成内存溢出,数据改为5万条并且写入之后查看内存信息:
public static void main(String[] args) {
String[] title ={ "id", "name", "sex" };
// 创建一个工作簿
Workbook workbook =new XSSFWorkbook();
// 创建一个工作表sheet
Sheet sheet =workbook.createSheet();
// 创建第一行
Row row =sheet.createRow(0);
// 创建一个单元格
Cell cell =null;
// 创建表头
for (int i =0; i
cell =row.createCell(i);
cell.setCellValue(title[i]);
}
// 从第二行开始追加数据
for (int i =1; i <=50000; i++) {
// 创建第i行
Row nextRow =sheet.createRow(i);
// 参数代表第几列
Cell cell2 =nextRow.createCell(0);
cell2.setCellValue("a" +i);
cell2 =nextRow.createCell(1);
cell2.setCellValue("user" +i);
cell2 =nextRow.createCell(2);
cell2.setCellValue("男");
}
// 创建一个文件
File file =new File("C:/Users/YZS/Desktop/常用/tt1.xls");
try {
file.createNewFile();
// 打开文件流
FileOutputStream outputStream =new FileOutputStream(file);
workbook.write(outputStream);
outputStream.close();
// dispose of temporary files backing this workbook on disk
// ((SXSSFWorkbook) workbook).dispose();
System.out.println("创建完成");
System.out.println("总的内存->" +Runtime.getRuntime().totalMemory() /1024 /1024 +"MB");
System.out.println("剩余的内存->" +Runtime.getRuntime().freeMemory() /1024 /1024 +"MB");
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
将上面XSSF改为SXFFS查看结果:
创作不易,如果这篇文章对你有用,请点个赞谢谢?(?ω?)?!
猜你喜欢
- 2024-10-11 搞定Excel繁琐操作:一起轻松掌握EasyExcel的使用技巧
- 2024-10-11 「软件更新」MyExcel 3.0.0.RC 发布:重构&性能提升
- 2024-10-11 多功能 Excel 工具包 MyExcel(excel工具大全)
- 2024-10-11 Java使用poi进行excel的导入操作(java poi操作excel)
- 2024-10-11 SpringBoot实现Excel导入导出,好用到爆,POI可以扔掉了
- 2024-10-11 AI领域的“新常态”:面对“AI幻觉”,我们该怎么办?
- 2024-10-11 Java8如何让Excel的读写变得更加简单高效
- 2024-10-11 JAVA POI实现大数据量excel文件读写及导出
- 2024-10-11 java使用导出百万级别数据?(java百万数据excel导入)
- 2024-10-11 高级Java研发师在解决大数据问题上的一些技巧
你 发表评论:
欢迎- 最近发表
-
- 给3D Slicer添加Python第三方插件库
- Python自动化——pytest常用插件详解
- Pycharm下安装MicroPython Tools插件(ESP32开发板)
- IntelliJ IDEA 2025.1.3 发布(idea 2020)
- IDEA+Continue插件+DeepSeek:开发者效率飙升的「三体组合」!
- Cursor:提升Python开发效率的必备IDE及插件安装指南
- 日本旅行时想借厕所、买香烟怎么办?便利商店里能解决大问题!
- 11天!日本史上最长黄金周来了!旅游万金句总结!
- 北川景子&DAIGO缘定1.11 召开记者会宣布结婚
- PIKO‘PPAP’ 洗脑歌登上美国告示牌
- 标签列表
-
- ifneq (61)
- messagesource (56)
- aspose.pdf破解版 (56)
- promise.race (63)
- 2019cad序列号和密钥激活码 (62)
- window.performance (66)
- qt删除文件夹 (72)
- mysqlcaching_sha2_password (64)
- ubuntu升级gcc (58)
- nacos启动失败 (64)
- ssh-add (70)
- jwt漏洞 (58)
- macos14下载 (58)
- yarnnode (62)
- abstractqueuedsynchronizer (64)
- source~/.bashrc没有那个文件或目录 (65)
- springboot整合activiti工作流 (70)
- jmeter插件下载 (61)
- 抓包分析 (60)
- idea创建mavenweb项目 (65)
- vue回到顶部 (57)
- qcombobox样式表 (68)
- vue数组concat (56)
- tomcatundertow (58)
- pastemac (61)
本文暂时没有评论,来添加一个吧(●'◡'●)