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

参考文章

相关推荐
2501_930707784 小时前
使用C#代码向 Word 文档添加文档属性
开发语言·c#·word
IT一氪19 小时前
一款 AI 驱动的 Word 文档翻译工具
人工智能·word
东方佑1 天前
使用Python标准库将Word文档转换为HTML:深入解析.docx文件处理脚本
python·html·word
wtsolutions1 天前
Sheet-to-Doc 支持 JSON 和 JSONL 格式:批量生成 Word 文档的新方式
json·word·wtsolutions·sheet-to-doc
伟贤AI之路1 天前
原创分享:Word 转 Markdown - 精准还原 Word 格式、支持 LaTeX 公式与表格
word
开开心心_Every2 天前
优化C盘存储:自定义软件文档保存路径工具
java·网络·数据库·typescript·word·asp.net·excel
gc_22992 天前
学习C#调用OpenXml操作word文档的基本用法(9:读取文档基本属性)
word·openxml·基本属性
bu_shuo3 天前
word中的文本显示有灰色底纹
word
青啊青斯3 天前
python markdown转word【包括字体指定】
开发语言·python·word