SpringBoot項目使用POI-TL動態生成Word文檔

????????近期項目工作需要動態生成Word文檔的需求,特意調研了動態生成Word的技術方案。主要有以下兩種:

  • 第一種是FreeMarker模板來進行填充;
  • 第二種是POI-TL技術使用Word模板來進行填充;

以下是關于POI-TL的官方介紹

重點關注:word模版一定、一定、一定要使用Microsoft Word來進行生成,不能使用WPS或其他工具生成。

本例按一下步驟進行講解

1、準備Word模版文件

2、創建SpringBoot工程并配置pom.xml文件

       <dependency><groupId>com.deepoove</groupId><artifactId>poi-tl</artifactId><version>1.10.0</version></dependency><dependency><groupId>org.apache.poi</groupId><artifactId>poi</artifactId><version>4.1.2</version></dependency><dependency><groupId>org.apache.poi</groupId><artifactId>poi-ooxml</artifactId><version>4.1.2</version></dependency><dependency><groupId>org.apache.poi</groupId><artifactId>poi-ooxml-schemas</artifactId><version>4.1.2</version></dependency><dependency><groupId>org.apache.poi</groupId><artifactId>poi-scratchpad</artifactId><version>4.1.2</version></dependency><dependency><groupId>commons-io</groupId><artifactId>commons-io</artifactId><version>2.7</version></dependency>

3、創建實體對象

Device.java

@Data
@ApiModel
public class Device {@ApiModelProperty(value = "設備ID",name = "deviceId")private Long deviceId ;/** 裝備名稱 */@ApiModelProperty(value = "設備名稱",name = "deviceName")private String deviceName ;/** 裝備類型 */@ApiModelProperty(value = "設備類型",name = "deviceType")private String deviceType ;/** 裝備型號 */@ApiModelProperty(value = "設備型號",name = "deviceModel")private String deviceModel ;/** 裝備用途 */@ApiModelProperty(value = "設備用途",name = "deviceUse")private String devicetUse ;/** 生產廠家 */@ApiModelProperty(value = "生產廠家",name = "manufacturer")private String manufacturer ;/** 采購日期 */@JsonFormat(pattern = "yyyy-MM-dd")@ApiModelProperty(value = "采購日期(yyyy-MM-dd)",name = "purchaseDate")private Date purchaseDate ;

3、編寫數據渲染邏輯

            String templateTargetPath = "D:"+ File.separator + "P" + RandomUtil.randomNumbers(10) + ".docx";File templateTargetFile = new File(templateTargetPath);Map<String, Object> mapData = new HashMap();mapData.put("deviceList", deviceList);mapData.put("pipeList", pipeList);mapData.put("taskName", "測試任務"); //渲染數據LoopRowTableRenderPolicy loopRowTableRenderPolicy = new LoopRowTableRenderPolicy();Configure configure = Configure.builder().bind("deviceList", loopRowTableRenderPolicy).bind("pipeList", loopRowTableRenderPolicy).build();//讀取模板文件InputStream inputStream = new FileInputStream(new File(templatePath+ File.separator + "方案信息.docx"));XWPFTemplate template = XWPFTemplate.compile(inputStream, configure).render(mapData);//目標文件template.writeToFile(templateTargetPath);template.close();

注:LoopRowTableRenderPolicy?是一個特定場景的插件,根據集合數據循環表格行。

表格動態內容填充,POI-TL提供了3種方式。

  • 表格行循環
  • 表格列循環
  • 動態表格。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/83202.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/83202.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/83202.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

fakeroot 在沒有超級用戶權限的情況下模擬文件系統的超級用戶行為

fakeroot 是一個在 Linux 環境中使用的工具&#xff0c;它允許用戶在沒有超級用戶權限的情況下模擬文件系統的超級用戶行為。它是一個在 Linux 環境中廣泛使用的工具&#xff0c;通常包含在大多數 Linux 發行版的軟件倉庫中。? 主要功能 ?模擬 root 權限?&#xff1a;fake…

Spring Spring Boot 常用注解整理

Spring & Spring Boot 常用注解整理 先理解核心概念&#xff1a;什么是注解&#xff08;Annotation&#xff09;&#xff1f;第一部分&#xff1a;IOC&#xff08;控制反轉&#xff09;和 DI&#xff08;依賴注入&#xff09;1. Component2. Service, Repository, Controll…

AIGC與數字媒體實驗室解決方案分享

第1部分 概述 1.1 建設目標 1.深度融合AIGC技術&#xff0c;培養能夠駕馭新質生產力的數字媒體人才 通過引入前沿的AIGC技術&#xff0c;確保學生能夠接觸到最先進的人工智能應用。教學內容理論和實踐結合&#xff0c;讓學生在實際操作中熟練掌握AIGC工具&#xff0c;生成高…

訊聯云庫項目開發日志(二)AOP參數攔截

目錄 利用AOP實現參數攔截: 一、??HTTP請求進入Controller?&#xff08;發送郵件驗證碼&#xff09; 二、AOP切面觸發 1. 切面攔截&#xff08;GlobalOperactionAspect.class&#xff09; method.getAnnotation()?? null interceptor 判斷?? 2.參數校驗注解 3. 參…

用OBD部署OceanBase社區版的避坑指南

以下是用OBD黑屏部署 OceanBase社區版時容易碰到的幾個問題及解決思路&#xff0c;供大家參考。 一、 遇坑步驟&#xff1a;用yaml文件部署集群&#xff1a; obd cluster deploy obtest -c mini-single-example.yaml 報錯&#xff1a; Package oceanbase-ce-4.2.1.8-108000…

無錫哲訊科技:引領芯片封裝SAP系統的智能化革命

芯片封裝行業的數字化轉型 在全球半導體產業高速發展的今天&#xff0c;芯片封裝作為產業鏈的關鍵環節&#xff0c;直接影響著芯片的性能、可靠性和成本。隨著5G、人工智能、物聯網等技術的普及&#xff0c;市場對芯片的需求激增&#xff0c;封裝企業面臨著效率提升、良率優…

從海洋生物找靈感:造個機器人RoboPteropod,它能在水下干啥?

大家好&#xff01;在如今人類對水下環境探索不斷深入的時代&#xff0c;從水下考古到珊瑚礁考察&#xff0c;各種任務都離不開水下機器人的助力。但傳統水下機器人尺寸較大&#xff0c;在狹窄的水下空間施展不開。今天&#xff0c;我們就來認識一款受海洋小生物啟發而設計的仿…

區塊鏈blog1__合作與信任

&#x1f342;我們的世界 &#x1f33f;不是孤立的&#xff0c;而是網絡化的 如果是單獨孤立的系統&#xff0c;無需共識&#xff0c;而我們的社會是網絡結構&#xff0c;即結點間不是孤立的 &#x1f33f;網絡化的原因 而目前并未發現這樣的理想孤立系統&#xff0c;即現實中…

Linux服務之lvs+keepalived nginx+keepalived負載均衡實例解析

目錄 一.LVSKeepAlived高可用負載均衡集群的部署 二.NginxKeepAlived高可用負載均衡集群的部署 一.LVSKeepAlived高可用負載均衡集群的部署 實驗環境 主keepalived&#xff1a;192.168.181.10 lvs &#xff08;7-1&#xff09; 備keepalived&#xff1a;192.168.181.10…

50天50個小項目 (Vue3 + Tailwindcss V4) ? |搭建項目框架

&#x1f5a4; 一個專注于「Vue3 TailwindCSS」的 50 天極簡開發挑戰&#xff0c;探索組件邊界&#xff0c;打磨技術鋒芒。 &#x1f389; 歡迎來到 50 個小項目的第一天&#xff01;今天我們將從零開始搭建一個 Vue3 項目&#xff0c;并引入 Tailwind CSS v4&#xff0c;為后…

Android 中 網絡圖片加載庫 Glide 簡介

Glide 是一個功能強大且廣泛使用的圖片加載庫,適用于 Android 應用程序。它提供了簡單易用的 API,用于從網絡、本地存儲或資源中加載圖片,并支持圖片的緩存、轉換、占位圖、動畫等功能。 一、Glide 主要特點 簡單易用 提供簡潔的 API,一行代碼即可加載圖片。 支持多種數據…

07 web 自動化之 Unittest 應用:測試報告裝飾器斷言

文章目錄 一、常見的第三方庫結合 unittest 生產 html 格式測試報告1、HtmlTestRunner2、BeatifulReport 二、裝飾器 unittest.skip 強制跳過&條件跳過三、unittest的常用斷言方法 一、常見的第三方庫結合 unittest 生產 html 格式測試報告 1、HtmlTestRunner 官網下載 …

【Python 面向對象】

Python 的面向對象編程&#xff08;OOP&#xff09;通過類&#xff08;Class&#xff09;和對象&#xff08;Object&#xff09;實現代碼結構化&#xff0c;支持封裝、繼承和多態三大特性。以下是系統化指南&#xff1a; 一、類與對象基礎 1. 定義類 class Dog:# 類屬性&…

STM32F103_LL庫+寄存器學習筆記23 - PWM波形輸出及軟件方式調整周期與占空比

導言 脈寬調制&#xff08;PWM&#xff09;是 STM32 定時器最常用的輸出模式之一&#xff0c;廣泛應用于電機驅動、LED 調光、伺服控制和功率管理等場景。本篇文章將以 TIM5 為例&#xff0c;從寄存器層面深入剖析 PWM 輸出的原理與實現步驟。通過本篇博客&#xff0c;你不僅能…

堆(Heap)

1. 堆&#xff08;Heap&#xff09; 1.1. Python實現堆的插入、堆頂刪除和排序 class MaxHeap:def __init__(self):# 初始化空堆&#xff0c;使用列表表示self.heap []def insert(self, val):# 插入元素并執行上浮self.heap.append(val)self._sift_up(len(self.heap) - 1)de…

Spring類

BeanDefinition BeanDefinition表示Bean定義&#xff0c;BeanDefinition中存在很多屬性用來描述一個Bean的特點。比如&#xff1a; class&#xff0c;表示Bean類型scope&#xff0c;表示Bean作用域&#xff0c;單例或原型等lazyInit&#xff1a;表示Bean是否是懶加載initMeth…

在vue中this.$emit有哪些作用,事件監控具體含義,以及這些子組件能封裝哪些功能組件

this.$emit 的作用 this.$emit 的作用是觸發一個自定義事件&#xff0c;并將數據傳遞給父組件。父組件可以通過 v-on&#xff08;或 &#xff09;監聽這個事件&#xff0c;并在事件觸發時執行相應的處理函數。 this.content 的作用 this.content 是子組件的 props&#xff0…

前端流行框架Vue3教程:16. 組件事件配合`v-model`使用

組件事件配合v-model使用 如果是用戶輸入&#xff0c;我們希望在獲取數據的同時發送數據配合v-model 來使用&#xff0c;幫助理解組件間的通信和數據綁定。 &#x1f9e9; 第一步&#xff1a;創建子組件&#xff08;SearchComponent.vue&#xff09; 這個組件用于處理用戶的搜…

《Navicat之外的新選擇:實測支持國產數據庫的SQLynx核心功能解析》

數據庫工具生態的新變量 在數據庫管理工具領域&#xff0c;Navicat長期占據開發者心智。但隨著國產數據庫崛起和技術信創需求&#xff0c;開發者對工具的兼容性、輕量化和本土化適配提出了更高要求。近期體驗了一款名為SQLynx的國產數據庫管理工具&#xff08;麥聰旗下產品&am…

AgenticSeek開源的完全本地的 Manus AI。無需 API,享受一個自主代理,它可以思考、瀏覽 Web 和編碼,只需支付電費。

?一、軟件介紹 文末提供程序和源碼下載 AgenticSeek開源的完全本地的 Manus AI。無需 API&#xff0c;享受一個自主代理&#xff0c;它可以思考、瀏覽 Web 和編碼&#xff0c;只需支付電費。這款支持語音的 AI 助手是 Manus AI 的 100% 本地替代品 &#xff0c;可自主瀏覽網頁…