当前位置:   article > 正文

Java工具总结:将数据内容写入excel文件_java生成excel文件并写入数据

java生成excel文件并写入数据

Java工具总结:将数据内容写入excel文件

一、背景

Java项目开发中,经常会遇到这样的需求:将数据内容写入excel文件。这里开发了一个将数据内容写入excel文件的工具类,直接调用工具方法即可实现这样的需求。

市面上也有其他类似的工具,但大多理解起来很困难,封装得太完美,很难基于它进行定制改造。

该工具类是基于org.apache.poi开发出来了,理解起来非常容易。该工具类做得也非常灵活,能够实现常见的需求,比如:设置列宽、对列合并单元格、设置背景颜色等等。

二、功能描述

使用该工具类将数据内容写入excel文件的过程中能够做下面这些事情:

  • 创建一个不存在的excel文件;
  • 在写入内容前,如果要写入的excel文件已经存在,会将该excel文件删除;
  • 可以创建出多个sheet页,并向这多个sheet页写入内容;
  • 每个sheet页,可以写入多个表格内容,每个表格之间会有一个空行;
  • 可以基于rgb(三原色)为单元格设置特定的颜色;
  • 可以设置表格列的宽度,设置的值,会被乘以256;
  • 可以设定值,代表前多少列,为前几列的每一列进行合并单元格;

例如:

在这里插入图片描述

优化:

2022年10月15日,对合并单元格功能进行了优化,通过指定要进行单元格合并的范围,就能进行灵活的单元格合并:

        // 指定要合并的单元格的范围
        // 某一个表格,  第1行到第2行, 第1列到5列。进行合并单元格
        tableContent.setRowRange(Range.<Integer>closed(1, 2));
        tableContent.setColRange(Range.<Integer>closed(1, 5));
  • 1
  • 2
  • 3
  • 4

效果图如下:

灵活合并单元格

三、使用该工具类:Java代码演示

完整的演示代码: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;
    }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
  • 65
  • 66
  • 67
  • 68
  • 69
  • 70
  • 71
  • 72
  • 73
  • 74
  • 75
  • 76
  • 77
  • 78
  • 79
  • 80
  • 81
  • 82
  • 83
  • 84
  • 85
  • 86
  • 87
  • 88
  • 89
  • 90
  • 91
  • 92
  • 93
  • 94
  • 95
  • 96
  • 97
  • 98
  • 99
  • 100
  • 101
  • 102
  • 103
  • 104
  • 105
  • 106
  • 107
  • 108
  • 109
  • 110
  • 111
  • 112
  • 113
  • 114
  • 115
  • 116
  • 117
  • 118
  • 119
  • 120
  • 121
  • 122
  • 123
  • 124
  • 125
  • 126
  • 127
  • 128
  • 129
  • 130
  • 131
  • 132
  • 133
  • 134
  • 135
  • 136
  • 137
  • 138
  • 139
  • 140
  • 141
  • 142
  • 143

四、分析代码

完整的代码:mypoi-excel

4.1 几个重要的JavaBean:

  • ExcelContent:代表excel的所有内容数据,里面包含多有sheet页内容;
  • ExcelSheetContent :代表一个sheet页的内容,一个sheet页里面可以有多个不同“行数*列数”的二维表格;
  • TableContent:代表sheet页中,一个“行数*列数”的二维表格;
  • CellContent:单元格的内容;
  • MyCellColor:单元格的背景颜色,基于rgb三原色;

4.2 工具类的调用入口

工具类的调用入口为:MyExcelUtil.createNewExcelWriteContent(excelContent, excelFilePath)

传入两个参数:

  • excelContent:就是ExcelContent对象。
  • excelFilePath:要生成的excel文件路径。文件所在的文件夹路径必须存在。如果文件已经存在会被删除后重建。

五、更多实用的工具类

作者会不断总结出更多实用的Java开发工具类,可以在这里看到:Java开发中总结的非常实用的工具代码

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/花生_TL007/article/detail/538347
推荐阅读
相关标签
  

闽ICP备14008679号