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

    xml 复制代码
    		<!-- 用于生成word版报告 -->
    		<dependency>
    		    <groupId>com.deepoove</groupId>
    		    <artifactId>poi-tl</artifactId>
    		    <version>1.12.1</version>
    		</dependency>
  • 处理过程

    java 复制代码
    	// 模板文件
        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

java 复制代码
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 复制代码
// 前端js代码
// 如果此接口需要被鉴权,那么需要后端同时从Params中获取token,然后前端拼接token传递,否则此方法无法使用
// 需要注意跨域问题
window.location.href =  '你的接口地址';

插入图片

  • 模板:占位符格式是{{@xxxx}}
  • 代码
java 复制代码
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());

参考文章

相关推荐
萧鼎3 天前
深入解析 Python 的 Word 模板引擎:docxtpl 全面指南
开发语言·python·word
炒茄子3 天前
Word:解决关于目录中各级标题的点/前导符粗细大小样式不一的问题
word
缺点内向3 天前
C#: 如何自动化创建Word可填写表单,告别手动填写时代
c#·自动化·word
Knight_AL3 天前
docx4j vs LibreOffice:Java 中 Word 转 PDF 的性能实测
java·pdf·word
wtsolutions3 天前
Sheet-to-Doc实际应用案例:从邀请函到获奖通知
word
bu_shuo3 天前
将AI生成的数学公式正确复制到word中
人工智能·chatgpt·word·latex
为自己_带盐3 天前
在 Blazor Server 中集成 docx-preview.js 实现高保真 Word 预览
javascript·c#·word
公子如琢4 天前
在word方框中打√符号☑☒
word
筱歌儿6 天前
TinyMCE-----word表格本地图片转base64并上传
前端·word