最近接到一个需求-把多个查询结果导出到一个Excel(多个sheet页),然后把当时一起上传的附件压缩成一个zip,返回到前端,这对我一个对IO不太懂的人亦是雪上加霜,首先说一下整体流程,把所有数据利用ExcelUtilManySheet工具类,弄成一个Excel文件,放到临时目录(System.getProperty(“user.dir”)),接着把Minio文件地址转成文件,存放到临时目录.最后把临时目录的文件压缩,通过流的方式放回.再把临时目录删除.
1.多个查询结果放到一个Excel(多个sheet页),存到临时目录
工具类地址–>ruoyi-ExcelUtilManySheet
2.文件服务器链接转成文件
jdk自带FileUtils.copyURLToFile
3.文件压缩过程
工具类地址–>压缩工具类
我们当时上传附件的时候把文件名在后台保存了一份,及有一个在同一个文件夹里面,文件重名问题,这时候可以用HashSet来做一下校验(单一属性)
最后的最后,这个过程中可能遇到流不能完全关闭.解决方法就是System.gc.
我这里只提供一个思路,如果有什么问题,下面留言~
Java压缩文件工具类-Excel多个sheet工具类(实测有效)
最新推荐文章于 2024-09-20 21:48:23 发布