java Apache.poi导出Excel,导出合并单元格,增加样式导出

一. 业务场景,Excel导出合并单元格,效果如下!
预计效果
二。导入所需依赖
Apache POI是一个开源的Java库,用于读取和写入Microsoft Office格式的文件,如Word文档(.docx)、Excel表格(.xlsx)和PowerPoint幻灯片(.pptx)等。要在项目中使用Apache POI,你通常需要添加相应的依赖。

<dependency>  
    <groupId>org.apache.poi</groupId>  
    <artifactId>poi</artifactId>  
    <version>你的版本号</version>  
</dependency>  
  
<dependency>  
    <groupId>org.apache.poi</groupId>  
    <artifactId>poi-ooxml</artifactId>  
    <version>你的版本号</version>  
</dependency>

三。解决思路
1.获取到需要导出的数据,对需要合并的数据进行分组,需要合并的数据根据开始行,到分组后的数据作为结束行,进行合并!
1.1需要则创建表头,不需要则直接在本地获取模板进行写入!

   /**
     * 创建表头信息
     */
    public void createHeader(Sheet sheet, Workbook workbook) {
   
        Row row = sheet.createRow(0);
        row.setHeightInPoints(50);
        for (int i = 0; i < headList.size(); i++) {
   
            CellStyle cellStyle = WorkbookUtil.addExcelStyle(workbook, IndexedColors.GREY_25_PERCENT.index);
            Cell cell = row.createCell(i);
            cell.setCellValue(headList.get(i));
            cell.setCellStyle(cellStyle);
            sheet.setColumnWidth(i, (headList.get(i).length() + 10) * 256);
        }
        // 自动调整列宽以适应内容 setColumnWidth(int columnIndex, int width)
        sheet.setColumnWidth(2, 40 * 256);  //每个字符*256
        sheet.setColumnWidth(3, 20 * 256);
        sheet.setColumnWidth(9, 30 * 256);
        sheet.autoSizeColumn(0);
    }


    /**
     * 以下是我自己的一个导入案例
     */
@Override
    public void exportExcel(YwCostTask costTask, HttpServletResponse response) {
   
        String year = costTask.getYear();
        try {
   
            List<YwCostTask> list = this.list(Condition.getLikeQueryWrapper(costTask));
            // 创建一个新的工作簿
            Workbook workbook = new XSSFWorkbook();
            //配置样式
            CellStyle cellStyle = WorkbookUtil.addCellStyle(workbook);
            Font font = WorkbookUtil.addFontStyle(workbook);
            Map<String, Map<String, List<YwCostTask>>> collect = list.stream().collect(Collectors.groupingBy(YwCostTask::getYear, Collectors.groupingBy(YwCostTask::getContractNo)));
            List<String> contractNos = collect.values().stream().flatMap(map -> map.keySet().stream()).collect(Collectors.toList()); //获取出所有的合同编号
            //通过合同编号查询其他年份的子项目
            Map<String, List
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值