[alibaba/easyexcel]模板填充导致样式变更。

2024-05-09 646 views
7
    @Test
    @SneakyThrows
    public void simpleFill() {
        // 模板注意 用{} 来表示你要用的变量 如果本来就有"{","}" 特殊字符 用"\{","\}"代替
        String templateFileName = "D:\\simple.xlsx";
        // 方案2 根据Map填充
        String fileName = "D:" + File.separator + "simpleFill" + System.currentTimeMillis() + ".xlsx";
// 方案1
        try (ExcelWriter excelWriter = EasyExcel.write(fileName).withTemplate(templateFileName).build()) {
            WriteSheet writeSheet = EasyExcel.writerSheet().build();
            WriteSheet sheet2 = EasyExcel.writerSheet("Sheet2").build();
            WriteSheet sheet3 = EasyExcel.writerSheet("Sheet3").build();
            // 这里注意 入参用了forceNewRow 代表在写入list的时候不管list下面有没有空行 都会创建一行,然后下面的数据往后移动。默认 是false,会直接使用下一行,如果没有则创建。
            // forceNewRow 如果设置了true,有个缺点 就是他会把所有的数据都放到内存了,所以慎用
            // 简单的说 如果你的模板有list,且list不是最后一行,下面还有数据需要填充 就必须设置 forceNewRow=true 但是这个就会把所有数据放到内存 会很耗内存
            // 如果数据量大 list不是最后一行 参照下一个

            ArrayList<FillData> fillData = new ArrayList<>();
            for (int i = 0; i < 5; i++) {
                fillData.add(new FillData().setList(i + "测试").setList1(i + "list444444"));
            }

            FillConfig fillConfig = FillConfig.builder().forceNewRow(Boolean.TRUE).build();
            excelWriter.fill(fillData, fillConfig, writeSheet);

            Map<String, Object> map = MapUtils.newHashMap();
            map.put("name", "2019年10月9日13:28:28");
            map.put("number", "2019年10月9日13:28:28");
            map.put("total", 1000);
            excelWriter.fill(map, writeSheet);

            FillData2 fillData2 = new FillData2();
            fillData2.setName_1("张三");
            fillData2.setSex("男");
            excelWriter.fill(fillData2, writeSheet);
            excelWriter.fill(fillData2, sheet2);
            excelWriter.fill(fillData2, sheet3);
        }
    }

异常提示 导出的模板文件: simple.xlsx

如图: imageE3 的地方,想要填充一个list
按照配置,增加了:forceNewRowTrue
导出之后未发现新建行,而是覆盖了该红色行。
image

希望是新建N(list 的数量) 行。 应该怎么操作?

        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>easyexcel</artifactId>
            <version>3.1.3</version>
        </dependency>

建议描述

回答

6

用FillWrapper就没问题了~