根据Word模板,使用POI生成文档

突然想起来有个小作业:需要根据提供的Word模板填充数据。这里使用POI写了一个小demo验证下。

测试用模板:

执行结果

1.引入依赖坐标

xml 复制代码
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi-ooxml</artifactId>
            <version>4.1.2</version>
        </dependency>
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi</artifactId>
            <version>4.1.2</version>
        </dependency>

2.获取相关数据的方法

java 复制代码
    private static Object getValueFromData(String key) {
        // 根据需要实现此方法以从数据源获取值
        // 例如,从数据库、配置文件或用户输入中获取值
        Map<String, Object> textMap = new HashMap<String, Object>();
        textMap.put("title","《模板》");
        textMap.put("myName","--尉某人--");
        textMap.put("today","2023-11-02");

        List<Map> tables = new ArrayList<Map>();
        Map<String, String> tableMap = new HashMap<String, String>();
        tableMap.put("name","尉某人");
        tableMap.put("age","26");
        tableMap.put("phone","189*******");
        tables.add(tableMap);
        tableMap = new HashMap<String, String>();
        tableMap.put("name","王某人");
        tableMap.put("age","28");
        tableMap.put("phone","186*******");
        tables.add(tableMap);
        tableMap = new HashMap<String, String>();
        tableMap.put("name","张某人");
        tableMap.put("age","24");
        tableMap.put("phone","130*******");
        tables.add(tableMap);
        textMap.put("tables",tables);

        return textMap.get(key);
    }

3.解析模板并填充数据

java 复制代码
    public static void readTemplate() throws Exception {
        // 读取Word模板文件
        FileInputStream fis = new FileInputStream("C:\\Users\\Desktop\\template.docx");
        XWPFDocument document = new XWPFDocument(fis);

        // 获取所有段落
        List<XWPFParagraph> paragraphs = document.getParagraphs();
        for (XWPFParagraph paragraph : paragraphs) {
            List<XWPFRun> runs = paragraph.getRuns();
            for (XWPFRun run : runs) {
                String text = run.getText(0);
                if (text != null && text.startsWith("${")) {
                    String key = text.substring(2, text.length() - 1);
                    String value = getValueFromData(key).toString(); 
                    run.setText(value, 0);
                }
            }
        }
        // 获取表格
        List<XWPFTable> rowTables = document.getTables();
        for (XWPFTable table : rowTables) {
            // 遍历表格的每一行
            for (XWPFTableRow row : table.getRows()) {
                row.getCell(0).setText("尉某人");
                row.getCell(1).setText("26");
                row.getCell(2).setText("おひさしぶりだな");
            }
        }

        // 创建表格并填充数据
        List<Map> tables = (List<Map>) getValueFromData("tables");
        int size = tables.size();
        XWPFTable table = document.createTable(size+1, 3);
        table.getRow(0).getCell(0).setText("姓名");
        table.getRow(0).getCell(1).setText("年龄");
        table.getRow(0).getCell(2).setText("联系方式");

        for (int i = 0; i < tables.size(); i++) {
            Map<String,String> map = tables.get(i);
            XWPFTableRow row = table.getRow(i + 1);
            row.getCell(0).setText(map.get("name"));
            row.getCell(1).setText(map.get("age"));
            row.getCell(2).setText(map.get("phone"));
        }


        // 保存文件
        FileOutputStream fos = new FileOutputStream("C:\\Users\\Desktop\\output.docx");
        document.write(fos);
        fos.close();
        document.close();
        fis.close();
    }

4.测试结果

java 复制代码
    public static void main(String[] args){
        try {
            readTemplate();
            System.out.println("执行成功!!!");
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
相关推荐
猿来入此小猿7 分钟前
基于SSM实现的健身房系统功能实现十六
java·毕业设计·ssm·毕业源码·免费学习·猿来入此·健身平台
goTsHgo44 分钟前
Spring Boot 自动装配原理详解
java·spring boot
卑微的Coder1 小时前
JMeter同步定时器 模拟多用户并发访问场景
java·jmeter·压力测试
pjx9871 小时前
微服务的“导航系统”:使用Spring Cloud Eureka实现服务注册与发现
java·spring cloud·微服务·eureka
多多*2 小时前
算法竞赛相关 Java 二分模版
java·开发语言·数据结构·数据库·sql·算法·oracle
爱喝酸奶的桃酥2 小时前
MYSQL数据库集群高可用和数据监控平台
java·数据库·mysql
唐僧洗头爱飘柔95272 小时前
【SSM-SSM整合】将Spring、SpringMVC、Mybatis三者进行整合;本文阐述了几个核心原理知识点,附带对应的源码以及描述解析
java·spring·mybatis·springmvc·动态代理·ioc容器·视图控制器
骑牛小道士3 小时前
Java基础 集合框架 Collection接口和抽象类AbstractCollection
java
alden_ygq3 小时前
当java进程内存使用超过jvm设置大小会发生什么?
java·开发语言·jvm
triticale3 小时前
【Java】网络编程(Socket)
java·网络·socket