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

分sheet写入excel

了解您想用 EasyExcel 实现分批查询数据并写入不同 Sheet 的需求,这对于处理大量数据导出非常有用。下面我将为您梳理核心的实现思路、关键代码示例以及一些实用的注意事项。

📝 核心实现思路

利用 EasyExcel 实现分批查询数据并写入不同 Sheet 的核心在于​​分页查询​​与​​多 Sheet 写入机制​​的结合。其基本流程如下:

  1. ​计算总分页数与 Sheet 数​​:根据数据总量、每个 Sheet 容纳的数据行数(如 100 万行)以及每次查询的数据量(如 20 万行),计算出需要多少个 Sheet 以及每个 Sheet 需要查询多少次。

  2. ​创建 ExcelWriter​​:在开始导出前,初始化一个 ExcelWriter对象。

  3. ​循环写入每个 Sheet​​:外层循环控制 Sheet 的创建,内层循环进行分页查询和数据写入。

  4. ​关闭资源​​:在所有数据写入完成后,务必调用 excelWriter.finish()来关闭写入器并释放资源,这对于避免内存泄漏和确保文件完整性至关重要 。

具体的操作步骤和关键决策点,可以参考下面的流程图,它清晰地展示了从数据查询到最终生成多 Sheet Excel 文件的完整过程:

flowchart TDA[开始导出] --> B[计算总数据量<br>确定Sheet数和分页数]B --> C[创建ExcelWriter]C --> D{是否还有Sheet要处理?}D -- 是 --> E[创建新Sheet]E --> F{是否完成当前Sheet的写入?}F -- 否 --> G[分页查询下一批数据]G --> H[将数据写入当前Sheet]H --> FF -- 是 --> DD -- 否 --> I[关闭ExcelWriter<br>finish]I --> J[导出完成]

💻 关键代码示例与解释

以下是一个简化的代码框架,展示了如何实现上述流程。代码中包含了关键步骤的注释说明。

// 1. 准备输出流和ExcelWriter(通常在实际项目中与HttpServletResponse绑定)
String fileName = "batch_export_example.xlsx";
ExcelWriter excelWriter = EasyExcel.write(fileName).build();// 2. 定义常量:每个Sheet的数据量、每次查询的数据量
int perSheetRows = 1000000; // 每个Sheet存放100万行数据
int pageSize = 200000;      // 每次查询20万行
int totalCount = 5000000;   // 总数据量500万行(实际场景中需从数据库查询count)// 3. 计算需要的Sheet数量和每个Sheet需要写入的次数
int totalSheets = (totalCount + perSheetRows - 1) / perSheetRows; // 向上取整// 4. 外层循环:遍历每个Sheet
for (int sheetIndex = 0; sheetIndex < totalSheets; sheetIndex++) {// 创建新的Sheet,可设置Sheet名称WriteSheet writeSheet = EasyExcel.writerSheet(sheetIndex, "数据Sheet_" + (sheetIndex + 1)).head(YourDataModel.class) // 指定数据模型类,用于生成表头.build();// 5. 内层循环:计算当前Sheet的数据范围,并进行分页查询和写入int startRow = sheetIndex * perSheetRows;int endRow = Math.min((sheetIndex + 1) * perSheetRows, totalCount);int currentPage = 1;int currentPosition = startRow;while (currentPosition < endRow) {// 计算当前页实际应查询的数据量int currentPageSize = Math.min(pageSize, endRow - currentPosition);// 分页查询数据(假设您的分页查询方法返回List<YourDataModel>)List<YourDataModel> dataBatch = yourDataService.getDataBatch(currentPage, currentPageSize);// 将查询到的数据写入当前SheetexcelWriter.write(dataBatch, writeSheet);currentPage++;currentPosition += currentPageSize;}
}// 6. 非常重要:关闭ExcelWriter,释放资源
excelWriter.finish();

​代码关键点说明:​

  • ​数据模型类 (YourDataModel)​​:这是一个普通的 Java 类,使用 @ExcelProperty注解来映射 Excel 的表头。例如,@ExcelProperty("姓名") private String name;

  • ​分页查询方法 (yourDataService.getDataBatch)​​:您需要根据自己项目的持久化框架(如 MyBatis-Plus、JPA 等)实现一个分页查询方法,根据页码和页面大小返回数据列表。

  • ​Sheet 命名​​:通过 EasyExcel.writerSheet方法可以指定 Sheet 的索引和名称。

  • ​资源释放​​:excelWriter.finish()是必须调用的方法,它确保所有数据被正确写入文件并关闭相关输出流 。

⚠️ 注意事项与优化建议

  1. ​性能与内存管理​​:

    • ​批量大小​​:pageSize(每批查询的数据量)需要根据实际情况调整。太小会导致数据库查询频繁,太大则可能增加单次内存占用。通常建议在几千到几万条之间进行测试和选择 。

    • ​流式导出​​:EasyExcel 本身设计为低内存占用。对于超大数据量(如百万行以上),其写入机制能有效避免内存溢出(OOM)。

  2. ​样式与格式​​:

    • ​自动列宽​​:可以注册 LongestMatchColumnWidthStyleStrategy策略,让 EasyExcel 自动根据单元格内容调整列宽,提升 Excel 文件的可读性 。

    • ​自定义样式​​:如果需要设置单元格边框、字体、对齐方式等,可以通过实现 WriteHandler接口或使用 HorizontalCellStyleStrategy来自定义样式 。

  3. ​Web 环境下的导出​​:

    • 当在 Controller 中处理 HTTP 导出请求时,需要正确设置 HttpServletResponse的响应头(如 Content-Type、Content-Disposition),并将 OutputStream传递给 EasyExcel.write

希望这些详细的说明和代码示例能帮助您顺利实现功能!如果您在具体实现过程中遇到更细致的问题,例如特定场景的优化,我们可以继续深入探讨。

http://www.dtcms.com/a/410989.html

相关文章:

  • 怎么把网站黑了传统文化网站建设
  • 【开题答辩全过程】以 SpringBootVue的旅游租车管理系统为例,包含答辩的问题和答案
  • Windows配置PicGo+Gitee图床——解决你的MarkDown笔记分享无图片的问题
  • 网站排名alexawordpress 商城安全
  • 【开题答辩过程】以《分布式菌菇销售系统》为例,不会开题答辩的可以进来看看
  • 广州优化网站关键词静态网站用什么做
  • 油棕种植密度控制:单位面积产值与光照利用优化
  • 紫金桥软件:深耕工业数据价值,赋能智造未来
  • Unity / C# 闭包详解 —— 按钮回调、协程、事件中的坑与修复
  • 使用Windbg分析dmp文件的方法以及实战分析实例分享
  • 什么是m3u8协议
  • 富文本编辑器Tinymce的使用、语言包配置、工具栏与工具栏组添加
  • 西安网站优化seo网站ico在后台哪里找到
  • 生成式人工智能教育应用的治理策略:构建“法律-伦理-标准”三位一体治理体系
  • 哪些行业对做网站的需求大qux wordpress
  • 智能中控终端:多系统联动管控中枢-LKONE立控信息
  • Mac M2安装VUE3
  • clang编译器 abseil-cpp中的ABSL_MUST_USE_RESULT
  • 网站营销怎么做做公众号用什么网站吗
  • ReactUse 是一个为 React 开发者设计的实用工具库(陀螺仪、地理位置、虚拟列表、标签页通讯函数)
  • ORB-SLAM2之ORB特征提取
  • 【Anaconda】anaconda卸载重安装
  • 安徽元鼎建设公司网站opensns wordpress
  • 企业做的网站计入什么科目免费logo设计的网站
  • AI助手融合架构方案:融合“路由-执行”模式与Nacos 3.0的智能工具调用系统 (含核心实现代码)
  • (基于江协科技)51单片机入门:1.LED
  • 网上做任务挣钱的网站wordpress首页刷新不变
  • 西安信誉好的做网站的一键网页转app生成器
  • 二手硬件升级实战:5000元Threadripper 3960X AI工作站组装指南
  • 兑吧集团受邀参加2025华康会·DaJK大健康“源头创新·链动未来”创新论坛