根据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();
        }
    }
相关推荐
Yeats_Liao19 分钟前
Spring 框架:配置缓存管理器、注解参数与过期时间
java·spring·缓存
Yeats_Liao19 分钟前
Spring 定时任务:@Scheduled 注解四大参数解析
android·java·spring
码明19 分钟前
SpringBoot整合ssm——图书管理系统
java·spring boot·spring
某风吾起23 分钟前
Linux 消息队列的使用方法
java·linux·运维
xiao-xiang26 分钟前
jenkins-k8s pod方式动态生成slave节点
java·kubernetes·jenkins
取址执行38 分钟前
Redis发布订阅
java·redis·bootstrap
S-X-S1 小时前
集成Sleuth实现链路追踪
java·开发语言·链路追踪
快乐就好ya1 小时前
xxl-job分布式定时任务
java·分布式·spring cloud·springboot
沉默的煎蛋1 小时前
MyBatis 注解开发详解
java·数据库·mysql·算法·mybatis
Aqua Cheng.1 小时前
MarsCode青训营打卡Day10(2025年1月23日)|稀土掘金-147.寻找独一无二的糖葫芦串、119.游戏队友搜索
java·数据结构·算法