java通过poi-tl导出word实战详细步骤

文章目录

poi-tl是一个基于Apache POI的Word模板引擎,也是一个免费开源的Java类库,你可以非常方便的加入到你的项目中,并且拥有着让人喜悦的特性。中文网站

  • 可以通过word模版引擎渲染文本、图片、表格、列表数据
  • 可以渲染条形图(3D条形图)、柱形图(3D柱形图)、面积图(3D面积图)、折线图(3D折线图)、雷达图、饼图(3D饼图)、散点图等图表渲染
  • 可以根据条件隐藏或者显示某些文档内容(包括文本、段落、图片、表格、列表、图表等)
  • 可以根据集合循环某些文档内容(包括文本、段落、图片、表格、列表、图表等)
  • 支持设置书签,文档内锚点和超链接功能
  • 模板即样式,同时代码也可以设置样式
  • 插件化设计,在文档任何位置执行函数

与其他模版引擎对比

1.引入maven依赖包

(1)引入poi-tl包

xml 复制代码
<dependency>
  <groupId>com.deepoove</groupId>
  <artifactId>poi-tl</artifactId>
  <version>1.12.2</version>
</dependency>

(2)因为poi-tl依赖于Apache POI5.2.2+,所以必须映入poi依赖包

xml 复制代码
<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi-ooxml</artifactId>
    <version>5.2.2</version>
</dependency>

<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi</artifactId>
    <version>5.2.2</version>
</dependency>
<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi-ooxml-schemas</artifactId>
    <version>4.1.2</version>
</dependency>
<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi-scratchpad</artifactId>
    <version>5.2.2</version>
    <scope>compile</scope>
</dependency>

(3)继续 引入poi-tl需要的commons-io与log4j-api依赖包(必须引入,否则会报错,报错如下)

xml 复制代码
<dependency>
    <groupId>commons-io</groupId>
    <artifactId>commons-io</artifactId>
    <version>2.11.0</version>
</dependency>

<dependency>
    <groupId>org.apache.logging.log4j</groupId>
    <artifactId>log4j-api</artifactId>
    <version>2.14.1</version>
</dependency>

不引入会导致报错,报错如下:

2.新建Word文档exportWprd.docx模版

在静态资源目录下resources/static/templates新建exportWord.docx,编写以下模版内容:

3.编写导出word接口代码

java 复制代码
  @GetMapping("/exportWord")
  public void exportWord(HttpServletResponse response) throws FileNotFoundException {
      //存放数据,也就是填充在word里面的值
      Map<String, Object> params = new HashMap<>();
      params.put("title","测试使用poi-tl模版导出word");
      params.put("ceshi","测试使用poi-tl模版导出word");
      params.put("name","张三");
      params.put("text","知之为知之不知为不知");

      //模板路径
      // String templatePath = "E:\\demo\\word.docx";
      // 或模板在静态资源的相对路径
      File rootFile = new File((ResourceUtils.getURL("classpath:").getPath()));
      File templateFile = new File(rootFile, "/static/templates/exportWord.docx");
      //jar包获取不到文件路径`
      //URLDecoder.decode() 解决获取中文名称文件路径乱码
      String templatePath = URLDecoder.decode(templateFile.getPath());
      //生成文件名
      String fileName = new SimpleDateFormat("yyyyMMddHHmmss").format(new Date()) + "_" + System.currentTimeMillis();
      // 导出wold
      try {
          // 导出Word文档为文件
          XWPFTemplate template = XWPFTemplate.compile(templatePath).render(params);
          // 将导出的Word文件转换为流
          response.setContentType("application/octet-stream");
          response.setHeader("Content-disposition","attachment;filename=\""+fileName+".docx"+"\"");
          // HttpServletResponse response
          OutputStream out = response.getOutputStream();
          BufferedOutputStream bos = new BufferedOutputStream(out);
          template.write(bos);
          bos.flush();
          out.flush();
          // 最后不要忘记关闭这些流。
          PoitlIOUtils.closeQuietlyMulti(template, bos, out);
      } catch (Exception e) {
          System.out.println("导出Word文档时出现异常:" + e.getMessage());
      }
  }

4.导出成果

相关推荐
碎叶城李白17 分钟前
若依学习笔记1-validated
java·笔记·学习·validated
上单带刀不带妹23 分钟前
手写 Vue 中虚拟 DOM 到真实 DOM 的完整过程
开发语言·前端·javascript·vue.js·前端框架
都叫我大帅哥43 分钟前
🌊 Redis Stream深度探险:从秒杀系统到面试通关
java·redis
都叫我大帅哥44 分钟前
Redis持久化全解析:从健忘症患者到记忆大师的逆袭
java·redis
程序猿阿越1 小时前
Kafka源码(一)Controller选举与创建Topic
java·后端·源码
-凌凌漆-1 小时前
【Qt】QStringLiteral 介绍
开发语言·qt
程序员爱钓鱼1 小时前
Go语言项目工程化 — 常见开发工具与 CI/CD 支持
开发语言·后端·golang·gin
程序无bug1 小时前
Spring6 当中 Bean 的生命周期的详细解析:有五步,有七步,有十步
java
二川bro1 小时前
飞算智造JavaAI:智能编程革命——AI重构Java开发新范式
java·人工智能·重构