一. 业务场景,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