根据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();
        }
    }
相关推荐
墨染点香1 分钟前
LeetCode Hot100【6. Z 字形变换】
java·算法·leetcode
ldj202024 分钟前
SpringBoot为什么使用new RuntimeException() 来获取调用栈?
java·spring boot·后端
超龄超能程序猿25 分钟前
Spring 应用中 Swagger 2.0 迁移 OpenAPI 3.0 详解:配置、注解与实践
java·spring boot·后端·spring·spring cloud
风象南37 分钟前
SpringBoot配置属性热更新的轻量级实现
java·spring boot·后端
洛阳泰山38 分钟前
Spring Boot 整合 Nacos 实战教程:服务注册发现与配置中心详解
java·spring boot·后端·nacos
Y40900138 分钟前
C语言转Java语言,相同与相异之处
java·c语言·开发语言·笔记
YuTaoShao39 分钟前
【LeetCode 热题 100】994. 腐烂的橘子——BFS
java·linux·算法·leetcode·宽度优先
布朗克16839 分钟前
java常见的jvm内存分析工具
java·jvm·数据库
都叫我大帅哥2 小时前
深入浅出 Resilience4j:Java 微服务的“免疫系统”实战指南
java·spring cloud
Cao_Shixin攻城狮4 小时前
Flutter运行Android项目时显示java版本不兼容(Unsupported class file major version 65)的处理
android·java·flutter