poi-tl导出word

1、poi-tl是什么

poi-tl是一个基于Apache POI的Word模板引擎,同时它也是一个免费开源(github地址)的Java类库,给Java程序员带来了word处理上的便捷。

2、官方介绍

在文档的任何地方做任何事情(Do Anything Anywhere)是poi-tl的星辰大海。

2.1 poi-tl与其他word模板引擎的对比

方案 移植性 功能性 易用性

Poi-tl Java跨平台 Word模板引擎 基于Apache POI,更友好的API

Apache POI Java跨平台 Apache项目,不仅封装了易用的文档API(文本、图片、表格、页眉、页脚、图表等),也可以在底层直接操作XML结构 文档不全,这里有一个教程:Apache POI Word快速入门

Freemarker XML跨平台 仅支持文本,很大的局限性 不推荐,需要维护XML结构,代码后期不可维护

OpenOffice 部署OpenOffice,移植性较差 - 需要了解OpenOffice的API

HTML浏览器导出 依赖浏览器的实现,移植性较差 HTML不能很好的兼容Word的格式 -

Jacob、winlib Windows平台 - 复杂,完全不推荐使用

2.2 poi-tl的编码模式

TDO模式: Template + data-model = output

2.2.1 Template—模板

模板即Docx格式的Word文档

2.2.2 Data-model—数据

数据即模板中需要替换的数据结构,类似哈希或者字典,常用Map结构,其中key即需要替换的标签

2.2.3 Output—输出

输出即最终文档的流产生,可以是文件流或网络流等

3、软件要求

Apache POI 4.1.2

jdk 1.8+

maven依赖

<dependency>

<groupId>com.deepoove</groupId>

<artifactId>poi-tl</artifactId>

<version>1.10.0</version>

</dependency>

4、标签

4.1 文本

标签

{{var}}数据模型

  1. String:文本
  2. TextRenderData:有样式的文本
  3. HyperlinkTextRenderData :超链接和锚点文本
  4. Object:调用 toString() 方法转化为文本

测试模板

​
package http://com.ruoyi.poiTl;

import http://com.deepoove.poi.XWPFTemplate;

import http://com.deepoove.poi.data.Texts;

import http://java.io.FileOutputStream;

import http://java.io.IOException;

import http://java.util.HashMap;

/**

* poi_tl导出word文档测试

* @author: lbx

* @create: 23/03/15 015

**/

public class DocTest {

public static void main(String[] args) throws IOException {

String filePath = "E:\\works\\zj\\ruoyi-admin\\src\\main\\resources\\testTest.docx";

String targetPath = "E:\\works\\zj\\ruoyi-admin\\src\\main\\resources\\textTestTarget.docx";

XWPFTemplate template = XWPFTemplate.compile(filePath).render(

new HashMap<String, Object>() {

{

put("name", "测试");

put("author", Texts.of("Liziba").color("000000").create());

put("link", Texts.of("百度").link("https://baidu.com").create());

put("anchor", Texts.of("anchortxt").anchor("appendix1").create());

}

});

template.writeAndClose(new FileOutputStream(targetPath));

}

}

​

测试结果

4.2 图片

标签

{{@var}}

数据模型

  1. String:图片url或者本地路径。默认使用图片自身尺寸
  2. PictureRenderData

测试模板

测试代码

​
package http://com.ruoyi.poiTl;

import http://com.deepoove.poi.XWPFTemplate;

import http://com.deepoove.poi.data.PictureType;

import http://com.deepoove.poi.data.Pictures;

import http://com.deepoove.poi.data.Texts;

import http://java.io.FileInputStream;

import http://java.io.FileOutputStream;

import http://java.io.IOException;

import http://java.util.HashMap;

/**

* 导出图片测试

*

* @author: lbx

* @create: 23/03/15 015

**/

public class PictureTest {

public static void main(String[] args) throws IOException {

String filePath = "E:\\works\\zj\\ruoyi-admin\\src\\main\\resources\\testTest.docx";

String targetPath = "E:\\works\\zj\\ruoyi-admin\\src\\main\\resources\\pictureTest2.docx";

String picPath = "E:\\works\\zj\\ruoyi-admin\\src\\main\\resources\\2056870.jpg";

XWPFTemplate template = XWPFTemplate.compile(filePath).render(

new HashMap<String, Object>() {

{

put("name", "测试");

put("author", Texts.of("Liziba").color("000000").create());

put("link", Texts.of("百度").link("https://baidu.com").create());

put("anchor", Texts.of("anchortxt").anchor("appendix1").create());

// 方法一、图片路径(原大小)

put("picture", picPath);

// 方法二、指定图片大小

put("picture", Pictures.ofLocal(picPath).size(3840, 2160).center().create());

// 方法三、图片流

put("picture", Pictures.ofStream(new FileInputStream(picPath), PictureType.JPEG)

.size(384, 216).create());

// 针对网络图片、SVG图片、Java图片都有处理

}

});

template.writeAndClose(new FileOutputStream(targetPath));

}

}

​

测试结果

4.3 表格

标签

{{#var}}

数据模型

  1. TableRenderData

测试模板

测试代码

​
package http://com.ruoyi.poiTl;

import http://com.deepoove.poi.XWPFTemplate;

import com.deepoove.poi.data.*;

import http://java.io.FileInputStream;

import http://java.io.FileOutputStream;

import http://java.io.IOException;

import http://java.util.HashMap;

/**

* @author: lbx

* @create: 23/03/15 015

**/

public class TableTest {

public static void main(String[] args) throws IOException {

String filePath = "E:\\works\\zj\\ruoyi-admin\\src\\main\\resources\\testTest.docx";

String targetPath = "E:\\works\\zj\\ruoyi-admin\\src\\main\\resources\\pictureTest2.docx";

String picPath = "E:\\works\\zj\\ruoyi-admin\\src\\main\\resources\\2056870.jpg";

// 表头

RowRenderData tableHead = Rows.of("姓名", "性别", "地址", "微信公众号").center().bgColor("4472c4").create();

// 第一行

RowRenderData row1 = Rows.create("张三", "男", "广东深圳", "liziba_98");

// 第二行

RowRenderData row2 = Rows.create("李四", "男", "广东深圳", "liziba_98");

// 合并第一行和第二行的第二列与第三列

MergeCellRule rule = MergeCellRule.builder().map(MergeCellRule.Grid.of(1, 1), MergeCellRule.Grid.of(2, 1))

.map(MergeCellRule.Grid.of(1, 2), MergeCellRule.Grid.of(2, 2)).build();

XWPFTemplate template = XWPFTemplate.compile(filePath).render(

new HashMap<String, Object>() {

{

put("name", "测试");

put("author", Texts.of("Liziba").color("000000").create());

put("link", Texts.of("百度").link("https://baidu.com").create());

put("anchor", Texts.of("anchortxt").anchor("appendix1").create());

// 方法一、图片路径(原大小)

put("picture", picPath);

// 方法二、指定图片大小

put("picture", Pictures.ofLocal(picPath).size(3840, 2160).center().create());

// 方法三、图片流

put("picture", Pictures.ofStream(new FileInputStream(picPath), PictureType.JPEG)

.size(384, 216).create());

// 针对网络图片、SVG图片、Java图片都有处理

put("table", Tables.of(tableHead, row1, row2).mergeRule(rule).center().create());

}

});

template.writeAndClose(new FileOutputStream(targetPath));

}

}

​

测试结果

4.4 列表、区块对、嵌套

5、总结

开发过程中,我们为了效率和可用性,都不大会考虑重复造轮子,在有成熟工具的时候选择一个合适的工具是一件事半功倍的事情,以上讲述了poi-tl的部分简单功能,看了上述编码方式也是仁者见仁智者见智吧,作者是非常喜欢通过poi-tl来处理word文档。具体其他特性读者可以去poi-tl的官网学习。

官网地址:http://deepoove.com/poi-tl

github地址:https://github.com/Sayi/poi-tl

  • 3
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值