EasyExcel 分次拼接

EasyExcel版本:2.2.7

在官方文档找了比较久, 没有找到对应的使用说明,这个版本是公司版本(因历史原因不能升级包),找方法找了比较久,这里记录一下

自己测试了30w的数据量(生成 + 上传文件系统)大概是60秒的样子

建议使用新版本的,文档啥的都很齐全,这种方法新版本也可以用;

                //这里创建一个输出的文件流
                File tempFile = File.createTempFile("PG_REGISTER", ".xlsx");
                FileOutputStream fileOutputStream = new FileOutputStream(tempFile);
                ExcelWriter excelWriter = EasyExcel.write(fileOutputStream).head(headList).registerWriteHandler(new LongestMatchColumnWidthStyleStrategy()).build();
                WriteSheet writeSheet = EasyExcel.writerSheet().build();

                //写入请求内容 这里是个人的循环写入方法
                setExcelWriter(excelWriter, writeSheet, dataQueryDto, queryVo);

                    excelWriter.write(detailList, writeSheet);
                    if (sequence != null){
                        setExcelWriter(excelWriter, writeSheet, dataQueryDto, queryVo);
                    }
                
                //用完之后finish一下
                excelWriter.finish();

                //文件太大又压缩了一下
                File zipFile = ZipUtil.zip(tempFile, StandardCharsets.UTF_8);
                FileInputStream fileInputStream = new FileInputStream(zipFile);
                //上传到文件系统
                String fastFileUrl = fastClientWrapper.uploadFile(fileInputStream, zipFile.length(), "zip", null);

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值