使用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格式。
热门推荐
桂陵之战:孙膑与庞涓的首次对决
龙血树开花时间及开花规律(探寻龙血树的生长与繁衍之道)
李世民与徐盛:孙膑兵法的现代启示
《孙膑兵法》中的智慧,教你职场制胜之道
孙膑VS庞涓:智慧与自大的对决
提升鼠标操作体验:从基本调节到进阶设置的全面指南
西湖醋鱼:杭州必打卡的地道美食
冬日打卡:杭州富阳最美自然景观
杭州私藏园林游赏攻略:郭庄、高庄、万松书院深度游
西湖美景不容错过!杭州旅游必打卡
都匀影视城免费拍大片!120元打造你的古装剧世界
探访都匀市·潘硐村:水族文化的守护者
都匀自驾游攻略:秦汉影视城穿越千年,螺丝壳徒步摄影两不误
斗篷山:贵州高原上的绿色明珠
都匀秦汉影视城:穿越时空的打卡胜地
元旦打卡腾冲冬游胜地!
春节穷游首选:云南腾冲温泉小镇
大连老年旅游全方位攻略:景点、美食、住宿及交通指南
焦作到岳阳自驾游,这些景点别错过!
春晚44年,那些难忘的精彩瞬间
冬至“饺子热”背后:商业力量如何守护文化记忆?
探访南京大报恩寺遗址公园和南唐二陵:冬日里的禅意之旅
南京大屠杀纪念馆与明孝陵:历史记忆与文化传承的双重地标
南京秋冬最美自然景观:栖霞山红叶与老山森林的绝美邂逅
秋冬心血管疾病预防指南:退休后必看!
国医大师姚希贤的健康之道:心态、饮食、运动一个都不能少
退休后环游世界?这波操作6到飞起!
【诚信宣传教育】为人之本,立业之基——诚信
AI赋能职教:高职院校的新布局与挑战
生成性AI重塑职业市场:2024年新趋势