Java poi-tl根据模板生成word文件的完整指南

 更新时间:2025年12月30日 09:25:35   作者:宋情写  
这篇文章主要为大家详细介绍了Java poi-tl根据模板生成word文件的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下

基础操作

本质上是通过占位符进行内容替换

本文章仅操作docx格式的文档

  • .doc (Word 97-2003): 使用OLE2格式,对应POI的 HWPF 组件
  • .docx (Word 2007+): 使用OOXML格式,对应POI的 XWPF 组件

基础操作_模板部分

将模板放入resources 资源目录下,自定义文件夹中,例如:templet/word_template/demo_template.docx

代码部分

maven

		<!-- 用于生成word版报告 -->
		<dependency>
		    <groupId>com.deepoove</groupId>
		    <artifactId>poi-tl</artifactId>
		    <version>1.12.1</version>
		</dependency>

处理过程

	// 模板文件
    String templateFilePath = "templet/word_template/demo_template.docx";
    // 读取模板文件
    InputStream templateIn = getClass().getClassLoader().getResourceAsStream(templateFilePath);

    // 插入文本数据
    Map<String, Object> templateData = new HashMap<String, Object>();
    templateData.put("str1", "替换成功");

    // 生成模板文件
    XWPFTemplate template = XWPFTemplate.compile(templateIn).render(templateData);
    
    // 写入数据并关闭流
    template.writeAndClose(new FileOutputStream("D:/output.docx"));
    templateIn.close();

此时,文件便下载到了 D:/output.docx 的位置。

若为Web

public void pgdExport(HttpServletResponse response) throws IOException {

        // 模板文件
        String templateFilePath = "templet/word_template/demo_template.docx";
        // 读取模板文件
        InputStream templateIn = getClass().getClassLoader().getResourceAsStream(templateFilePath);

        // 插入文本数据
        Map<String, Object> templateData = new HashMap<String, Object>();
        templateData.put("str1", "替换成功");

        // 生成模板文件
        XWPFTemplate template = XWPFTemplate.compile(templateIn).render(templateData);
        ServletOutputStream outputStream = response.getOutputStream();

        // 防止文件以及文件名乱码
        String fileName = "文件名.docx";
        String encodedFileName = URLEncoder.encode(fileName, "UTF-8").replaceAll("\\+", "%20");
        response.setContentType("application/vnd.openxmlformats-officedocument.wordprocessingml.document");
        response.setHeader("Content-Disposition", "attachment; filename=\"" + encodedFileName + "\"; filename*=utf-8''" + encodedFileName);
        response.setCharacterEncoding("UTF-8");

			  // 写入数据并关闭流
        template.writeAndClose(outputStream);
        templateIn.close();
    }
// 前端js代码
// 如果此接口需要被鉴权,那么需要后端同时从Params中获取token,然后前端拼接token传递,否则此方法无法使用
// 需要注意跨域问题
window.location.href =  '你的接口地址';

插入图片

模板:占位符格式是{{@xxxx}}

代码

import com.deepoove.poi.XWPFTemplate;
import com.deepoove.poi.data.PictureType;
import com.deepoove.poi.data.Pictures;

templateData.put("img", Pictures.ofStream(in, PictureType.JPEG).size(300, 300).create());

参考文章:Java poi-tl根据模版生成word文件并插入文字、图片、表格、图表

到此这篇关于Java poi-tl根据模板生成word文件的完整指南的文章就介绍到这了,更多相关Java poi-tl模板生成word内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Springboot的配置文件及其优先级说明

    Springboot的配置文件及其优先级说明

    文章介绍了Spring Boot的配置文件,包括application.properties和application.yml的使用,以及它们的优先级,还讨论了如何通过外置配置文件覆盖内置配置文件,并使用@Value注解读取自定义属性
    2025-12-12
  • Spring多线程通过@Scheduled实现定时任务

    Spring多线程通过@Scheduled实现定时任务

    这篇文章主要介绍了Spring多线程通过@Scheduled实现定时任务,@Scheduled 定时任务调度注解,是spring定时任务中最重要的,下文关于其具体介绍,需要的小伙伴可以参考一下
    2022-05-05
  • Java线程创建的四种方式总结

    Java线程创建的四种方式总结

    这篇文章主要介绍了Java线程创建的四种方式,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-09-09
  • 理解JPA注解@GeneratedValue的使用方法

    理解JPA注解@GeneratedValue的使用方法

    这篇文章主要介绍了理解JPA注解@GeneratedValue的使用方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-07-07
  • SpringBoot应用部署到外置Tomcat的实现

    SpringBoot应用部署到外置Tomcat的实现

    SpringBoot内置tomcat使用很方便,本文主要介绍了SpringBoot应用部署到外置Tomcat的实现,具有一定的参考价值,感兴趣的可以了解一下
    2024-07-07
  • MyBatis Plus中代码生成器使用详解

    MyBatis Plus中代码生成器使用详解

    这篇文章主要介绍了MyBatis Plus中代码生成器使用详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-08-08
  • Spring Boot 2.6.x整合Swagger启动失败报错问题的完美解决办法

    Spring Boot 2.6.x整合Swagger启动失败报错问题的完美解决办法

    这篇文章主要给大家介绍了关于Spring Boot 2.6.x整合Swagger启动失败报错问题的完美解决办法,文中通过实例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2022-03-03
  • Java关键字synchronized基本使用详解

    Java关键字synchronized基本使用详解

    这篇文章主要给大家介绍了关于Java关键字synchronized基本使用的相关资料,synchronized可以用来同步静态和非静态方法,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2024-01-01
  • Maven搭建springboot项目的方法步骤

    Maven搭建springboot项目的方法步骤

    这篇文章主要介绍了Maven搭建springboot项目的方法步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-04-04
  • JSON在Java中的使用方法实例

    JSON在Java中的使用方法实例

    对于java来说,json的对象也是分为JSONObject和JSONArray这两种,每种对象的操作方式不一样哦,下面这篇文章主要给大家介绍了关于JSON在Java中使用的相关资料,需要的朋友可以参考下
    2023-03-03

最新评论