iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > JAVA >JAVA:使用POI SXSSFWorkbook方式导出Excel大数据文件
  • 336
分享到

JAVA:使用POI SXSSFWorkbook方式导出Excel大数据文件

javaexcelmicrosoft 2023-09-01 09:09:32 336人浏览 薄情痞子
摘要

Apache POI 是用Java编写的免费开源的跨平台的 Java api,Apache POI提供API给Java对Microsoft Office格式档案读和写的功能。POI组件可以提供Java操作Microsoft Office的A

Apache POI 是用Java编写的免费开源的跨平台的 Java api,Apache POI提供API给Java对Microsoft Office格式档案读和写的功能。POI组件可以提供Java操作Microsoft Office的API,导出格式为Office 2003时POI调用的HSSF包,导出格式为Office 2007时,调用XSSF包,而SXSSF包是POI3.8版本之上对XSSF的一个扩展,用于大数据量的导出,实际应用中可有效避免内存溢出的问题。

注:excel2003(xls文件)支持每个工作表中最多有 65536 行和 256列,而Excel 2007(xlsx文件)支持每个工作表中最多有 1,048,576 行和 16,384 列。

以下介绍使用SXSSF方式导出大数据Excel文件的方法。

//获取数据(导出缓存文件)public void getCdateExcel() {                try {                    int pageSize=1000;//设置每批次写入的缓存行数                    Workbook workbook = new SXSSFWorkbook(pageSize);                    Sheet sh=workbook.createSheet();                    int rownum=0;                    //查询所有数据,此处若数据量过大,可能导致List对象内存溢出,需要使用多批次查询方式来限制每次仅查询部分数据,分多次查询结束最后write输出文件                    List list=getList();                    for(int i=0;iion e) {                    //                }    } 

示例说明

flushRows方法可以将达到行数的数据通过文件流输出到硬盘文件,并清空了缓存,避免大数据占用内存导致内存溢出的问题。

若查询到的数据过大可能会导致List队列中new对象剧增,导致JAVA创建对象内存溢出。此时需要将查询机制调整一下,一次性查询全部改为每次仅查询比如1000条数据。

不管单次还是分批次,最后一段代码中的write都会输出到硬盘,生成xlsx文件。

来源地址:https://blog.csdn.net/quan278905570/article/details/129530017

--结束END--

本文标题: JAVA:使用POI SXSSFWorkbook方式导出Excel大数据文件

本文链接: https://www.lsjlt.com/news/387913.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作