根据word模板生成word内容(JAVA)

主要是借助 poi-tl 来实现业务需求

当时第一次尝试的是Apache poi不是很好用,不推荐

第二次是xml,找的眼睛都花了,不推荐

要求:jdk1.8+,Apache POI5.2.2+ 我这里使用的是5.2.3版本

文档:Poi-tl Documentation

java 复制代码
<!-- Apache POI  -->
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi</artifactId>
            <version>5.2.3</version>
        </dependency>
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi-ooxml</artifactId>
            <version>5.2.3</version>
        </dependency>
        <dependency>
            <groupId>com.deepoove</groupId>
            <artifactId>poi-tl</artifactId>
            <version>1.12.2</version>
        </dependency>

注意这里需要确保没有其他的版本的poi,否则项目启动会报找不到类等错误,例如出现 java.lang.NoSuchFieldError:Factory

解决方式:此问题是由pom依赖导致,通过Ctrl+N查看ThemeDocument类,出现多个版本,发现引入了两个不同版本的poi包,导致版本冲突。

其中NoSuchMethodError 、ClassNotFoundException 、NoClassDefFoundError异常都是版本不对的问题,需要升级版本


代码部分

java 复制代码
// 利用map结构存储数据
            Map<String, Object> data = new HashMap<>();
// 指定路径 compile 编译模板 render添加数据源
XWPFTemplate template = XWPFTemplate.compile("xxx.docx").render(data);

  try {
                //write 输出到流
                template.writeAndClose(new FileOutputStream(输出路径"));
            } catch (IOException e) {
                e.printStackTrace();
                log.error("写入文件出错了");
            }

模板部分,使用poi-tl最大的难点或者说工作量在于模板的制作,具体可以看上面文档,文档中拥有具体格式。

  • 普通替换,只需要{{属性名}}
  • 逻辑判断是否显示:{{?属性名}}...{{/属性名}}
  • 列表{{*列表名}} 在这里,我单纯只使用了List<String>,文档中有更复杂的形式,包括对象
  • 表格我这里没有涉及到,不做考虑
相关推荐
lntu_ling20 分钟前
Python-基于Haversine公式计算两点距离
开发语言·python·gis算法
ShineWinsu6 小时前
对于C++:继承的解析—上
开发语言·数据结构·c++·算法·面试·笔试·继承
小付同学呀6 小时前
C语言学习(五)——输入/输出
c语言·开发语言·学习
码农阿豪6 小时前
Nacos 日志与 Raft 数据清理指南:如何安全释放磁盘空间
java·安全·nacos
梦幻精灵_cq6 小时前
学C之路:不可或缺的main()主函数框架(Learn-C 1st)
c语言·开发语言
直有两条腿6 小时前
【大模型】Langchain4j
java·langchain
love530love6 小时前
Scoop 完整迁移指南:从 C 盘到 D 盘的无缝切换
java·服务器·前端·人工智能·windows·scoop
消失的旧时光-19436 小时前
C++ 多线程与并发系统取向(二)—— 资源保护:std::mutex 与 RAII(类比 Java synchronized)
java·开发语言·c++·并发
莫寒清6 小时前
ThreadLocal
java·面试
福大大架构师每日一题7 小时前
go-zero v1.10.0发布!全面支持Go 1.23、MCP SDK迁移、性能与稳定性双提升
开发语言·后端·golang