当前位置: 首页 > news >正文

Java在word中指定位置插入图片。

Java使用(Poi-tl) 在word(docx)中指定位置插入图片

  • Poi-tl 简介
  • Maven 依赖配置
  • Poi-tl 实现原理与步骤
    • 1. 模板标签规范
    • 2.完整实现代码
    • 3.效果展示

Poi-tl 简介

Poi-tl 是基于 Apache POI 的 Java 开源文档处理库,专注于高效操作 Word 文档(.docx 格式)。它通过模板引擎机制简化复杂文档生成流程,相比原生 POI 具备更简洁的 API、更强的灵活性和更优的性能表现,广泛应用于报表生成、合同模板填充、文档批量处理等企业级场景。

Maven 依赖配置

<dependency><groupId>com.deepoove</groupId><artifactId>poi-tl</artifactId><version>1.12.0</version>
</dependency>

Poi-tl 实现原理与步骤

1. 模板标签规范

在 Word 模板中需使用特定格式的占位符标识图片插入位置,标准格式为:{{@标签名称}}。
示例标签格式:

{{@Head}}  <!-- 审核人签名位置 -->
{{@Approver}}  <!-- 批准人签名位置 -->

在这里插入图片描述

2.完整实现代码

import com.deepoove.poi.XWPFTemplate;
import com.deepoove.poi.data.PictureType;
import com.deepoove.poi.data.Pictures;import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.nio.file.Files;
import java.nio.file.Path;
import java.nio.file.StandardCopyOption;
import java.util.HashMap;
import java.util.Map;/*** Word文档图片插入工具类* 功能:通过Poi-tl在Word模板指定位置插入图片*/
public class WordImageInserter {/*** 主方法:执行Word图片插入操作*/public static void main(String[] args) {Path templatePath = Path.of("D:\\template.docx");        // 源文档模板路径Path outputPath= Path.of("D:\\template_temp.docx"); // 新文件路径Path inspectorImagePath = Path.of("D:\\signatures\\inspector.png"); // 审核人签名图片Path approverImagePath = Path.of("D:\\signatures\\approver.png");   // 批准人签名图片try {// 绑定模板占位符与图片渲染对象Map<String, Object> dataModel = new HashMap<>();dataModel.put("Head", createPicture(inspectorImagePath, 100, 50));     // 替换{{@Head}}标签dataModel.put("Approver", createPicture(approverImagePath, 100, 50)); // 替换{{@Approver}}标签// 执行文档渲染与图片插入try (InputStream templateStream = Files.newInputStream(templatePath);OutputStream tempOutputStream = Files.newOutputStream(tempOutputPath)) {// 编译模板并渲染数据XWPFTemplate template = XWPFTemplate.compile(templateStream).render(dataModel);// 输出到临时文件(避免直接修改原文件导致损坏)template.write(tempOutputStream);template.close();}// 原子性替换原文件(保证操作完整性)Files.move(tempOutputPath, templatePath, StandardCopyOption.REPLACE_EXISTING);System.out.println("图片插入操作完成,文档已更新");} catch (IOException e) {System.err.println("文档处理异常:" + e.getMessage());e.printStackTrace();}}/*** 构建图片渲染对象(支持尺寸自定义)* @param imagePath 图片文件路径* @param width 图片宽度(像素)* @param height 图片高度(像素)* @return 图片渲染对象(可直接用于模板渲染)* @throws IOException 图片读取失败时抛出*/private static Object createPicture(Path imagePath, int width, int height) throws IOException {// 使用NIO流加载图片,自动识别图片类型(此处显式指定为PNG)return Pictures.ofStream(Files.newInputStream(imagePath), PictureType.PNG).size(width, height)  // 自定义图片尺寸.create();           // 生成图片渲染实体}
}

3.效果展示

在这里插入图片描述

http://www.xdnf.cn/news/878851.html

相关文章:

  • idea json生成实体类
  • XTEA与TEA的区别
  • Git 安装全攻略Linux、macOS、Windows 与源码编译
  • 【hadoop】Flink安装部署
  • 如何利用Haption力反馈遥操作机器人解决远程操作难题
  • 【西门子杯工业嵌入式-2-点亮一颗LED】
  • bug 记录 - 使用 el-dialog 的 before-close 的坑
  • 【HarmonyOS 5】 影视与直播详以及 开发案例
  • 跑通 TrackNet-Badminton-Tracking-tensorflow2 项目全记录
  • 鸿蒙缺少WMIC missing WMIC
  • PPT转图片拼贴工具 v3.0
  • 鸿蒙仓颉语言开发实战教程:商城搜索页
  • 开关机、重启、改密、登录:图解腾讯云CVM日常管理核心操作,轻松掌控你的云主机
  • K8S认证|CKS题库+答案| 2. Pod 指定 ServiceAccount
  • k8s业务程序联调工具-KtConnect
  • Github Copilot新特性:Copilot Spaces-成为某个主题的专家
  • 【Web应用】若依框架:基础篇21二次开发-页面调整
  • 《C++初阶之类和对象》【命名空间 + 输入输出 + 缺省参数 + 函数重载】
  • OCR助力保险业建设
  • Redis持久化模式RDB与AOF
  • [论文阅读] 人工智能+项目管理 | 当 PMBOK 遇见 AI:传统项目管理框架的破局之路
  • Go语言学习笔记-创建一个Go项目
  • 瑞典Sana Agents全国部署:AI驱动的数字化转型革命
  • 适用于vue3的大屏数据展示组件库DataV(踩坑版)
  • Jenkins | Jenkins构建成功服务进程关闭问题
  • OD 算法题 B卷【BOSS的收入】
  • Docker Compose 备忘
  • 通过BUG(prvIdleTask、pxTasksWaitingTerminatio不断跳转问题)了解空闲函数(prvIdleTask)和TCB
  • 【C++ Qt】窗口(Qt窗口框架、菜单栏QMenuBar)
  • 高效集成AI能力:使用开放API打造问答系统,不用训练模型,也能做出懂知识的AI