使用POI-TL通过Word模板生成Word文件
创作时间:
作者:
@小白创作中心
使用POI-TL通过Word模板生成Word文件
引用
CSDN
1.
https://blog.csdn.net/moshowgame/article/details/81702029
技术背景
在网站或系统开发中,常常需要生成Word文件供用户下载打印,例如证明文件或订单文件。Apache POI是Java操作Word文档最流行的库,本文将介绍如何使用POI-TL库通过Word模板生成Word文件。
Maven依赖
要使用POI-TL库,需要在项目的pom.xml文件中添加以下依赖:
<dependency>
<groupId>com.deepoove</groupId>
<artifactId>poi-tl</artifactId>
<version>1.3.1</version>
</dependency>
核心实现代码
以下是一个简单的示例,展示了如何通过一个制作好的Word模板文件,填充数据生成新的Word文件:
@RestController
public class PoiController {
@GetMapping("/generateWord")
public ApiReturnObject generateWord(String data) {
// 模板文件路径
String wordPath = "C:\\Users\\Administrator\\Desktop\\";
String modelName = "人物模板.docx";
String outputName = "hanyunxi.docx";
// 准备数据
Map<String, Object> datas = new HashMap<>();
datas.put("name", "鞠婧祎");
datas.put("team", "前SNH48");
datas.put("gender", "女");
datas.put("birthday", "19940618");
datas.put("remark", "鞠婧祎,1994年6月18日出生于四川遂宁,毕业于四川音乐学院附属中学,中国女演员、歌手,原SNH48 TEAM NII成员");
// 填充数据并生成新的Word文件
XWPFTemplate template = XWPFTemplate.compile(wordPath + modelName).render(datas);
try (FileOutputStream out = new FileOutputStream(wordPath + outputName)) {
template.write(out);
} catch (IOException e) {
e.printStackTrace();
}
return ApiReturnUtil.success(data);
}
}
支持的模板标签
POI-TL支持多种类型的模板标签,包括文本、图片、表格和编号列表等。以下是一些示例:
文本标签:
put("author", new TextRenderData("000000", "Sayi卅一")); put("introduce", "http://www.deepoove.com");图片标签:
put("localPicture", new PictureRenderData(120, 120, "./sayi.png"));表格标签:
put("changeLog", new TableRenderData( new ArrayList<RenderData>() {{ add(new TextRenderData("d0d0d0", "")); add(new TextRenderData("d0d0d0", "introduce")); }}, new ArrayList<Object>() {{ add("1;add new # gramer"); add("2;support insert table"); add("3;support more style"); }}, "no datas", 10600));编号列表标签:
put("feature", new NumbericRenderData(new ArrayList<TextRenderData>() {{ add(new TextRenderData("Plug-in grammar")); add(new TextRenderData("Supports word text, header...")); add(new TextRenderData("Not just templates, but also style templates")); }}));
运行效果
以下是生成的Word文件的运行效果截图:
注意事项
如果在使用过程中遇到以下错误:
org.apache.poi.openxml4j.exceptions.OLE2NotOfficeXmlFileException: The supplied data appears to be in the OLE2 Format. You are calling the part of POI that deals with OOXML (Office Open XML) Documents. You need to call a different part of POI to process this data (eg HSSF instead of XSSF)
这通常是因为文件后缀名错误。POI-TL封装的是docx格式的版本,因此需要确保使用的模板文件是docx格式。
热门推荐
游戏美术中的中华传统美食元素
2025年烘焙流行的风往哪吹?
张宿(张月鹿):二十八星宿中的南方朱雀第五宿
这种凶猛的小鸟与霸王龙生活在一起
7000多个岗位!刚下动车直接面试,小伙惊了,“杭州你真的很宠!”
关于龙的手抄报有哪些?龙的手抄报创意主题大盘点:让你的作品脱颖而出!
滇西版哀牢山——高黎贡山,竟藏着一条宝藏徒步路线!
三星手机截屏功能使用指南:三种方式轻松捕捉精彩瞬间
周三004 欧冠 多特蒙德VS里斯本竞技
克里米亚战争:一场被遗忘的现代化战争
我们为什么读古书?——《蒙学经典》
术前将血压控制在什么范围,术后不良事件发生最少?
国内有哪些景点旅游时不容错过?
五行代表的身体部位
个人IP运营打造分享:知识经验本身不值钱,要成为行走的解决方案!
低碳再生水泥应用于混凝土性能研究
水泥分散剂:如何改善混凝土工作性
很多人的病是吃出来的!4个小改变,血脂降了、血糖低了、脂肪肝变好了
最低工资标准由哪些因素决定
心理学:成年人的觉醒,从不再抱怨“原生家庭”开始!
八字如何影响命运 八字与性格的关联
高效透明的保险理赔:行业的关键与挑战
UWB高精度定位系统:标签类型与实际应用场景解析
揭开'龙飞'之谜:蜻蜓为何叫dragonfly?
UE5室内设计案例分享:从客餐厅到卧室的现代家居空间
牛肉一炖就老?没用对方法!学会3个技巧,牛肉软烂入味,好吃
熬夜真的致癌又变丑!如何获得高质量睡眠?
广东“佛山新城”的独特地标建筑:有人觉得好看,有人觉得丑?
金牛座和白羊座是否不合?深入分析兩者的性格和相處之道
“五一”火车票候补成功的概率大吗?回程的机票、车票记得提前买