easypoi导出纵向合并列,模版导出纵向合并相同数据

public void exportExcel(String month, HttpServletResponse response) {
        List<ChamberInfoVo> chamberInfoVoList = this.tableStatistics(month);
        TemplateExportParams params = new TemplateExportParams();
        if (chamberInfoVoList.size() > 0) {
            try {
                response.setContentType("application/octet-stream");
                //取到要生成的模板
                try {
                    params = new TemplateExportParams(quantityStatisticsPath, true);
                } catch (Exception e) {
                    throw new RuntimeException("模板路径不存在!");
                }
                Map<String, Object> map = new HashMap<>();
                map.put("date", month);
                List<Map<String, String>> listMap = new ArrayList<Map<String, String>>();
                int approvedNumberTotal = 0;
                int issueddNumberTotal = 0;
                for (ChamberInfoVo chamberInfoVo : chamberInfoVoList) {
                    approvedNumberTotal = approvedNumberTotal + Integer.valueOf(chamberInfoVo.getApprovedNumber());
                    issueddNumberTotal = issueddNumberTotal + Integer.valueOf(chamberInfoVo.getIssuedNumber());
                    Map<String, String> lm = new HashMap<String, String>();
                    lm.put("deptName", chamberInfoVo.getDeptName());
                    lm.put("chamberName", chamberInfoVo.getChamberName());
                    lm.put("approvedNumber", chamberInfoVo.getApprovedNumber());
                    lm.put("issueddNumber", chamberInfoVo.getIssuedNumber());
                    listMap.add(lm);
                }
                map.put("approvedNumberTotal", approvedNumberTotal);
                map.put("issueddNumberTotal", issueddNumberTotal);
                map.put("maplist", listMap);
                Workbook workbook = ExcelExportUtil.exportExcel(params, map);

                ByteArrayOutputStream outputStream = new ByteArrayOutputStream();
                workbook.write(outputStream);
                // 处理批示列的纵向合并
                PoiMergeCellUtil.mergeCells(workbook.getSheetAt(0), 2, 0);

                try {
                    response.setCharacterEncoding("UTF-8");
                    response.setHeader("content-Type", "application/vnd.ms-excel");
                    response.setHeader("Content-Disposition", "attachment;filename=" +
                            URLEncoder.encode(month + "月份公文数量统计导出", "UTF-8"));
                    OutputStream ouputStream = response.getOutputStream();
                    workbook.write(ouputStream);
                    ouputStream.flush();
                    ouputStream.close();
                } catch (IOException e) {
                    throw new RuntimeException(e);
                }
            } catch (IOException e) {
                throw new RuntimeException("导出失败!");
            }
        }
    }

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值