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());

参考文章

相关推荐
asdzx674 小时前
使用 C# 从 URL 下载 Word 文档
开发语言·c#·word
VBAMatrix1 天前
deepseek-v4正式接入Excel,一键生成财务分析报告
word·excel·审计·财务分析·deepseek·会计师事务所·tb工具箱
thethefighter1 天前
免安装在信创环境中使用word文档查看预览工具
word·信创·预览·银河麒麟·免安装·绿色·word预览工具
aisifang001 天前
PDF转Word神器:Gemini3.1Pro一键搞定文档处理
人工智能·pdf·word
Feibo20112 天前
如何在word里添加ppt
word·powerpoint
江南烟雨尘2 天前
Zotero管理Word参考文献,更新参考文献
word·论文笔记·zotero·参考文献
2501_907136823 天前
Word文档智能排版工具 (Word-Formatter-Pro)
word·软件需求
清风明月一壶酒3 天前
OpenClaw自动处理Word文档全流程
开发语言·c#·word
weixin_416660073 天前
豆包公式转Word,乱码解决
word·latex·豆包
寒山李白5 天前
解决 python-docx 生成的 Word 文档打开时弹出“无法读取内容“警告
python·word·wps·文档·docx·qoder