赞
踩
Java项目开发中,经常会遇到这样的需求:将数据内容写入excel文件。这里开发了一个将数据内容写入excel文件的工具类,直接调用工具方法即可实现这样的需求。
市面上也有其他类似的工具,但大多理解起来很困难,封装得太完美,很难基于它进行定制改造。
该工具类是基于org.apache.poi
开发出来了,理解起来非常容易。该工具类做得也非常灵活,能够实现常见的需求,比如:设置列宽、对列合并单元格、设置背景颜色等等。
使用该工具类将数据内容写入excel文件的过程中能够做下面这些事情:
例如:
优化:
2022年10月15日,对合并单元格功能进行了优化,通过指定要进行单元格合并的范围,就能进行灵活的单元格合并:
// 指定要合并的单元格的范围
// 某一个表格, 第1行到第2行, 第1列到5列。进行合并单元格
tableContent.setRowRange(Range.<Integer>closed(1, 2));
tableContent.setColRange(Range.<Integer>closed(1, 5));
效果图如下:
完整的演示代码:MyExcelUtilTest。
/** * 将数据内容写入excel文件 */ @Test public void createNewExcelWriteContentTest() { String excelFilePath = "/Users/lifei/Documents/opt/doc/demo01.xlsx"; ExcelContent excelContent = new ExcelContent(); List<ExcelSheetContent> sheetContentList = new ArrayList<>(); // 添加第一个sheet页的内容 sheetContentList.add(createFirstSheet()); // 添加第二个sheet页内容 sheetContentList.add(createSecondSheet()); // 添加多个sheet页的内容 excelContent.setSheetContentList(sheetContentList); MyExcelUtil.createNewExcelWriteContent(excelContent, excelFilePath); } /** * 创建第一个sheet * @return */ private ExcelSheetContent createFirstSheet() { // 第一个sheet页 ExcelSheetContent firstSheetContent = new ExcelSheetContent(); // 设置sheet页的名称 firstSheetContent.setSheetName("第一个sheet页"); List<TableContent> firstSheetTableList = new ArrayList<>(); // 第一个sheet页里的第一个表格 TableContent tableContent1 = createSheetFirstTable(); // 第一个sheet页里的第二个表格 TableContent tableContent2 = createSheetSecondTable(); // 第三个单元格:合并复杂单元格 TableContent tableContent3 = createSheetTable03(); // 添加表格 firstSheetTableList.add(tableContent1); firstSheetTableList.add(tableContent2); firstSheetTableList.add(tableContent3); // 往第一个sheet页中,添加多个表格 firstSheetContent.setTableContentList(firstSheetTableList); return firstSheetContent; } /** * 创建第一个表格 * @return */ private TableContent createSheetFirstTable() { TableContent tableContent = new TableContent(); tableContent.setTitle("第一个sheet页的第一个表格"); // 创建一个2行5列的表格 int rowNum = 3, colNum = 5; CellContent[][] table = new CellContent[rowNum][colNum]; table[0] = new CellContent[]{ new CellContent.Builder().cellValue("用户").builder(), new CellContent.Builder().cellValue("性别").builder(), new CellContent.Builder().cellValue("得分").builder(), new CellContent.Builder().cellValue("评价").builder(), new CellContent.Builder().cellValue("状态").builder() }; table[1] = new CellContent[]{ new CellContent.Builder().cellValue("小a").builder(), new CellContent.Builder().cellValue("男").builder(), new CellContent.Builder().cellValue("21").builder(), new CellContent.Builder().cellValue("好").myCellBGColor(new MyCellColor(51, 204, 51)).builder(), new CellContent.Builder().cellValue("在职").builder() }; table[2] = new CellContent[]{ new CellContent.Builder().cellValue("小b").builder(), new CellContent.Builder().cellValue("男").builder(), new CellContent.Builder().cellValue("10").builder(), new CellContent.Builder().cellValue("差").myCellBGColor(new MyCellColor(255, 153, 102)).builder(), new CellContent.Builder().cellValue("在职").builder() }; tableContent.setTable(table); // 添加标题颜色 tableContent.setTitleBGColor(new MyCellColor(153, 255, 153)); // 设置列宽 tableContent.setColumnWidthsBase256(new int[]{20, 20, 20, 20, 20}); // 设置标题居左 tableContent.setTitleAlignment(HorizontalAlignment.LEFT); // 前两列的每一列,合并单元格 tableContent.setMergeBeforeColNums(2); return tableContent; } /** * 创建第三个表格 * @return */ private TableContent createSheetTable03() { TableContent tableContent = new TableContent(); tableContent.setTitle("第三个表格:合并复杂的单元格"); // 创建一个5行5列的表格 int rowNum = 5, colNum = 5; CellContent[][] table = new CellContent[rowNum][colNum]; table[0] = new CellContent[]{ new CellContent.Builder().cellValue("用例").builder(), new CellContent.Builder().cellValue("产品1").builder(), new CellContent.Builder().cellValue("产品1").builder(), new CellContent.Builder().cellValue("产品2").builder(), new CellContent.Builder().cellValue("产品2").builder(), }; table[1] = new CellContent[]{ new CellContent.Builder().cellValue("用例").builder(), new CellContent.Builder().cellValue("版本").builder(), new CellContent.Builder().cellValue("数值").builder(), new CellContent.Builder().cellValue("版本").builder(), new CellContent.Builder().cellValue("数值").builder() }; table[2] = new CellContent[]{ new CellContent.Builder().cellValue("caseName-1").builder(), new CellContent.Builder().cellValue("v1.1").builder(), new CellContent.Builder().cellValue("200").builder(), new CellContent.Builder().cellValue("v1.2").builder(), new CellContent.Builder().cellValue("210").builder(), }; table[3] = new CellContent[]{ new CellContent.Builder().cellValue("caseName-2").builder(), new CellContent.Builder().cellValue("v0.1").builder(), new CellContent.Builder().cellValue("10").builder(), new CellContent.Builder().cellValue("v0.2").builder(), new CellContent.Builder().cellValue("11").builder(), }; table[4] = new CellContent[]{ new CellContent.Builder().cellValue("caseName-3").builder(), new CellContent.Builder().cellValue("v1.5").builder(), new CellContent.Builder().cellValue("0.3").builder(), new CellContent.Builder().cellValue("v1.5").builder(), new CellContent.Builder().cellValue("0.5").builder(), }; tableContent.setTable(table); // 添加标题颜色 tableContent.setTitleBGColor(new MyCellColor(153, 255, 153)); // 设置列宽 tableContent.setColumnWidthsBase256(new int[]{20, 20, 20, 20, 20}); // 设置标题居左 tableContent.setTitleAlignment(HorizontalAlignment.LEFT); // 指定要合并的单元格的范围 // 某一个表格, 第1行到第2行, 第1列到5列。进行合并单元格 tableContent.setRowRange(Range.<Integer>closed(1, 2)); tableContent.setColRange(Range.<Integer>closed(1, 5)); return tableContent; }
完整的代码:mypoi-excel
ExcelContent
:代表excel的所有内容数据,里面包含多有sheet页内容;ExcelSheetContent
:代表一个sheet页的内容,一个sheet页里面可以有多个不同“行数*列数”的二维表格;TableContent
:代表sheet页中,一个“行数*列数”的二维表格;工具类的调用入口为:MyExcelUtil.createNewExcelWriteContent(excelContent, excelFilePath)
。
传入两个参数:
excelContent
:就是ExcelContent
对象。excelFilePath
:要生成的excel文件路径。文件所在的文件夹路径必须存在。如果文件已经存在会被删除后重建。作者会不断总结出更多实用的Java开发工具类,可以在这里看到:Java开发中总结的非常实用的工具代码。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。