EasyExcel导出多个文件并直接打包成zip下载
String zipName = "xxx.zip";
try {
response.addHeader("Content-Disposition", "attachment;filename=" + URLEncoder.encode(zipName, "UTF-8"));
response.setContentType("application/vnd.ms-excel");
ZipOutputStream zos = new ZipOutputStream(response.getOutputStream());
ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream();
for (...) {
ZipEntry entry = new ZipEntry("*文件名*" + ".xlsx");
zos.putNextEntry(entry);
ExcelWriter build = EasyExcel.write(byteArrayOutputStream)
.withTemplate(new ClassPathResource("*模板路径*").getInputStream()).build();
FillConfig fillConfig = FillConfig.builder().forceNewRow(Boolean.TRUE).build();
WriteSheet sheet0 = EasyExcel.writerSheet(0).build();
build.fill("*数据集合1*", sheet0);
build.fill("*数据集合2*", fillConfig, sheet0);
...
build.finish();
zos.write(byteArrayOutputStream.toByteArray());
byteArrayOutputStream.reset();
}
zos.flush();
zos.close();
} catch (Exception e) {
e.printStackTrace();
}
yoojyn - 博客园
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通