使用easyExcel打包多个Excel文件下载

核心逻辑是多次写入ZipOutputStream

private void exportZip(LocalDate startDt, LocalDate endDt, HttpServletResponse response) throws IOException {
        // 这里URLEncoder.encode可以防止中文乱码
        String zipFileName = URLEncoder.encode("收费汇总表 - 多日汇总", "UTF-8").replaceAll("\\+", "%20");
        response.setHeader("Content-disposition", "attachment;filename*=utf-8''" + zipFileName + ".zip");
        response.setContentType("application/x-msdownload");
        response.setCharacterEncoding("utf-8");
        String templateFileName = FileUtil.getPath() + "template/收费汇总表模板.xlsx";
        templateFileName = URLDecoder.decode(templateFileName, "UTF-8").replaceAll("\\+", "%20");
        //开始存入
        try (ZipOutputStream zipOut = new ZipOutputStream(response.getOutputStream())) {
            while (!startDt.isAfter(endDt)) {
                List<BillSummary> billSummaryList = frDetailCheckService.getSummaryExcelData(startDt);
                ByteArrayOutputStream outputStream = new ByteArrayOutputStream();
                ExcelWriter excelWriter = EasyExcel
                        .write(outputStream)
                        .withTemplate(templateFileName)
                        .build();
                zipOut.putNextEntry(new ZipEntry(String.format("收费汇总表(%s).xlsx", DateUtil.formatLocalDate(startDt))));
                //开始写入excel
                WriteSheet writeSheet = EasyExcel.writerSheet().build();
                FillConfig fillConfig = FillConfig.builder().forceNewRow(Boolean.TRUE).build();
                excelWriter.fill(billSummaryList, fillConfig, writeSheet);
                excelWriter.fill(Maps.newHashMap("tradeDate", DateUtil.formatLocalDate(startDt)), fillConfig, writeSheet);
                excelWriter.finish();
                outputStream.writeTo(zipOut);
                zipOut.closeEntry();
                startDt = startDt.plusDays(1);
            }
        } catch (Exception e) {
            // 重置response
            response.reset();
            response.setContentType("application/json");
            response.setCharacterEncoding("utf-8");
            response.getWriter().println("下载文件失败" + e.getMessage());
        }
    }

    private void exportOne(LocalDate tradeDate, HttpServletResponse response) throws IOException {
        try {
            response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");
            response.setCharacterEncoding("utf-8");
            // 这里URLEncoder.encode可以防止中文乱码
            String fileName = URLEncoder.encode("收费汇总表", "UTF-8").replaceAll("\\+", "%20");
            response.setHeader("Content-disposition", "attachment;filename*=utf-8''" + fileName + ".xlsx");
            // 这里需要设置不关闭流
            String templateFileName = FileUtil.getPath() + "template/收费汇总表模板.xlsx";
            templateFileName = URLDecoder.decode(templateFileName, "UTF-8").replaceAll("\\+", "%20");
            List<BillSummary> list = frDetailCheckService.getSummaryExcelData(tradeDate);

            ExcelWriter excelWriter = EasyExcel
                    .write(response.getOutputStream())
                    .withTemplate(templateFileName)
                    .build();
            WriteSheet writeSheet = EasyExcel.writerSheet().build();
            FillConfig fillConfig = FillConfig.builder().forceNewRow(Boolean.TRUE).build();
            excelWriter.fill(Maps.newHashMap("tradeDate", DateUtil.formatLocalDate(tradeDate)), fillConfig, writeSheet);
            excelWriter.fill(list, fillConfig, writeSheet);
            excelWriter.finish();
        } catch (Exception e) {
            // 重置response
            response.reset();
            response.setContentType("application/json");
            response.setCharacterEncoding("utf-8");
            response.getWriter().println("下载文件失败" + e.getMessage());
        }
    }
  • 2
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值