POI-tl 知识整理:整理3 -> 动态生成表格

1 表格行循环

(1)需要渲染的表格的模板


说明{``{goods}} 是个标准的标签,将 {``{goods}} 置于循环行的上一行,循环行设置要循环的标签和内容,注意此时的标签应该使用 [] ,以此来区别poi-tl的默认标签语法。同理,{``{labors}} 也置于循环行的上一行。

(2)定义两个实体类

java 复制代码
@Data
public class Goods {
    private int count;
    private String name;
    private String desc;
    private int discount;
    private int tax;
}



@Data
public class Labors {
    private String category;
    private int people;
    private int price;
}

(3)测试代码

java 复制代码
    @Test
    public void autoGenerateTable1() throws Exception {
        // 数据
        Goods goods1 = new Goods();
        Goods goods2 = new Goods();
        Labors labors1 = new Labors();
        Labors labors2 = new Labors();

        goods1.setCount(2);
        goods1.setName("商品1");
        goods1.setDiscount(10);
        goods1.setDesc("商品1描述");
        goods1.setTax(5);

        goods2.setCount(4);
        goods2.setName("商品2");
        goods2.setDiscount(20);
        goods2.setDesc("商品2描述");
        goods2.setTax(10);
        List<Goods> goodsList = Arrays.asList(goods1, goods2);

        labors1.setPeople(3);
        labors1.setCategory("类别1");
        labors1.setPrice(100);

        labors2.setPeople(1);
        labors2.setCategory("类别2");
        labors2.setPrice(200);
        List<Labors> laborList = Arrays.asList(labors1, labors2);

        // 用行循环插件
        LoopRowTableRenderPolicy renderPolicy = new LoopRowTableRenderPolicy();
        ConfigureBuilder builder = Configure.builder();
        Configure configure = builder.bind("goods", renderPolicy).bind("labors", renderPolicy).build();

        XWPFTemplate template = XWPFTemplate.compile("D:\\Idea-projects\\POI_word\\templates_autoGenerateTable.docx",configure);

        Map<String, Object> map = new HashMap<>();
        map.put("goods", goodsList);
        map.put("labors", laborList);

        template.render(map);

        FileOutputStream fileOutputStream = new FileOutputStream("D:\\Idea-projects\\POI_word\\output_autoGenerateTable.docx");
        template.writeAndClose(fileOutputStream);

        template.close();
    }

(4)渲染结果

(5)测试代码详细解释


2 表格列循环

列循环跟行循环没有什么区别,就是将行循环插件换成了列循环插件
(1) 模板


(2)测试代码

java 复制代码
    @Test
    public void autoGenerateTable2() throws Exception {
        // 数据
        Labors labors1 = new Labors();
        Labors labors2 = new Labors();

        labors1.setPeople(3);
        labors1.setCategory("类别1");
        labors1.setPrice(100);

        labors2.setPeople(1);
        labors2.setCategory("类别2");
        labors2.setPrice(200);
        List<Labors> laborList = Arrays.asList(labors1, labors2);

        // 用列循环插件
        LoopColumnTableRenderPolicy renderPolicy = new LoopColumnTableRenderPolicy();
        ConfigureBuilder builder = Configure.builder();
        Configure configure = builder.bind("labors", renderPolicy).build();

        XWPFTemplate template = XWPFTemplate.compile("D:\\Idea-projects\\POI_word\\templates_autoGenerateTableCol.docx",configure);

        Map<String, Object> map = new HashMap<>();
        map.put("labors", laborList);

        template.render(map);

        FileOutputStream fileOutputStream = new FileOutputStream("D:\\Idea-projects\\POI_word\\output_autoGenerateTableCol.docx");
        template.writeAndClose(fileOutputStream);

        template.close();
    }


(3)渲染结果

相关推荐
JAVA学习通10 小时前
《大营销平台系统设计实现》 - 营销服务 第5节:抽奖前置规则过滤
java·数据库·github
斯特凡今天也很帅10 小时前
新建数据源报错No bean named ‘SqlSessionFactorykf‘ available
java·数据库·spring boot·mybatis
带刺的坐椅10 小时前
用 Solon AI 从零构建 MCP 工具服务:让 AI Agent 拥有真实世界的能力
java·ai·solon·mcp·solon-ai
TheRouter10 小时前
PromptCaching 工程实践:把LLM 调用成本砍掉80%
java·后端·spring·ai
寻道码路10 小时前
LangChain4j Java AI 应用开发实战(二):大模型参数调优实战:Temperature、TopP、MaxTokens 深度解析
java·开发语言·人工智能·aigc
SimonKing10 小时前
IP定位库的完美替代品:ip2region,开源、免费!
java·后端·程序员
XiYang-DING10 小时前
【Spring】Lombok
java·后端·spring
凤山老林10 小时前
AI辅助编程:Copilot在Java开发中的最佳实践
java·人工智能·copilot
ew4521810 小时前
【Java】Apache POI 终极封装:支持多表格循环、图片插入、日期格式化的Word导出工具类(兼容POI3.17+)
java·word·apache
铁打的阿秀10 小时前
IDEA启动项目报错: 加载主类 com.seeburger.webedi.system.SystemApplication 时出现 LinkageError
java·ide·intellij-idea