没有合适的资源?快使用搜索试试~ 我知道了~
Java使用POI导出大数据量Excel的方法
5星 · 超过95%的资源 32 下载量 90 浏览量
2020-08-25
09:17:19
上传
评论
收藏 50KB PDF 举报
温馨提示
试读
1页
今天需要写一个导出的Excel的功能,但是发现当数据量到3万条时,列数在23列时,内存溢出,CPU使用100%,测试环境直接炸掉。小编给大家分享基于java使用POI导出大数据量Excel的方法,感兴趣的朋友一起看看吧
资源推荐
资源详情
资源评论
Java使用使用POI导出大数据量导出大数据量Excel的方法的方法
今天需要写一个导出的Excel的功能,但是发现当数据量到3万条时,列数在23列时,内存溢出,CPU使用
100%,测试环境直接炸掉。小编给大家分享基于java使用POI导出大数据量Excel的方法,感兴趣的朋友一起看看
吧
今天需要写一个导出的Excel的功能,但是发现当数据量到3万条时,列数在23列时,内存溢出,CPU使用100%,测试环境直
接炸掉。在本地测试时发现,导出3000条左右的数据的时候,堆内存瞬间升高500M左右。然后发现了 SXSSFWorkbook 这
个类。
简介简介
SXSSFWorkbook 需要 poi-ooxml 包 3.8 及以上开始支持,我这边适使用的是 3.9 版本,本质是一个 XSSFWorkbook 类
( Excel2007 ),它使用的方式是采用 硬盘空间 来大幅降低 堆内存 的占用,在系统的临时文件夹目录创建一个临时文件,然后
将所有大于约定行数的数据都存入临时文件,而不是全部放在内存中,内存中只存放 最新的 的约定条数的数据,从而实现以
硬盘空间换取内存空间,避免内存溢出
使用方式使用方式
与正常的Excel导出方法没有区别,只是将实例化的类换为 SXSSFWorkbook
SXSSFWorkbook workbook = null;
OutputStream outputStream = null;
try {
outputStream = response.getOutputStream();
//创建工作簿
workbook = new SXSSFWorkbook();
// 打开压缩功能 防止占用过多磁盘
workbook.setCompressTempFiles(true);
// 创建一个工作表
Sheet sheet = workbook.createSheet("表名");
// 创建一行
Row titleRow = sheet.createRow(0);
// 创建一个单元格
Cell cell = titleRow.createCell(0);
// 给单元格赋值
cell.setCellValue("内容");
// 将工作簿写入输出流
workbook.write(outputStream);
} catch (Exception e) {
e.printStackTrace();
}finally {
if (workbook != null) {
//使用完毕后将产生的临时文件删除 防止将磁盘搞满
workbook.dispose();
}
if (outputStream != null) {
outputStream.close();
}
}
总结总结
以上所述是小编给大家介绍的Java使用POI导出大数据量Excel的方法,希望对大家有所帮助,如果大家有任何疑问请给我留
言,小编会及时回复大家的。在此也非常感谢大家对我们网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
资源评论
- 扈涧盛2023-07-25这个文件对于想要使用POI导出Excel的人来说是非常实用的。
- 臭人鹏2023-07-25作者以简洁明了的方式解释了Java使用POI导出Excel的方法,让我能够轻松上手。
- 吹狗螺的简柏承2023-07-25这篇文章对于处理大数据量的Excel导出问题给出了一种高效的解决方案。
- 家的要素2023-07-25文中提到的技巧对于优化导出Excel的性能有着显著的帮助。
- 梁肖松2023-07-25通过这篇文件,我学到了一个新的技能,提高了我的工作效率。
weixin_38721652
- 粉丝: 3
- 资源: 935
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功