Java如何使用spire進(jìn)行word文檔的替換詳解
前言
今天遇到一個(gè)需求,需要對(duì)word模板進(jìn)行替換制定的變量
在網(wǎng)上找了很多方案,做了很多的demo,下面就把我覺(jué)得比較簡(jiǎn)單的一種分享給大家
本次的主角是:spire.doc
spire.doc是專(zhuān)門(mén)實(shí)現(xiàn)對(duì)word的操作(包括文字,表格,圖片)
spire.doc介紹
Spire.Doc for .NET 是一款專(zhuān)門(mén)對(duì) Word 文檔進(jìn)行操作的 .NET類(lèi)庫(kù)。這款控件的主要功能在于幫助開(kāi)發(fā)人員輕松快捷高效地創(chuàng)建、編輯、轉(zhuǎn)換和打印 Microsoft Word 文檔。作為一款獨(dú)立的 Word .NET 控件,Spire.Doc for .NET 的運(yùn)行系統(tǒng)(服務(wù)器端或客戶端)均無(wú)需安裝 Microsoft Word,但是它卻可以將 Microsoft Word 文檔的操作功能集成到任何開(kāi)發(fā)人員的 .NET 應(yīng)用程序中。
Spire.Doc for .NET 能執(zhí)行多種 Microsoft Word 文檔處理任務(wù)的 .NET API。支持 Word97-2003,Word2007,Word2010 以及 Word2013。能在 Word 97/2003/2007/2010/2013 和 XML、RTF、TXT、XPS、EPUB、EMF、HTML、ODT 等格式文件之間進(jìn)行雙向轉(zhuǎn)換,還能將 Word 文件高質(zhì)量地轉(zhuǎn)換為 PDF 和 SVG 文件格式。
具體使用可以參考文檔: Spire.Doc for .NET 中文教程
前提準(zhǔn)備
準(zhǔn)備word模板
準(zhǔn)備一個(gè)word文件,里面簡(jiǎn)單寫(xiě)點(diǎn)模板:
引入spire.do依賴(lài)
spire.doc比較小眾,因此需要在pom.xml中導(dǎo)入spire.doc的倉(cāng)庫(kù),導(dǎo)入之后直接導(dǎo)包,如果不配置倉(cāng)庫(kù)直接下載依賴(lài)是不行的!
<dependency> <groupId>e-iceblue</groupId> <artifactId>spire.doc.free</artifactId> <version>3.9.0</version> </dependency> <repositories> <repository> <id>com.e-iceblue</id> <url>http://repo.e-iceblue.cn/repository/maven-public/</url> </repository> </repositories>
案例演示
前提工作準(zhǔn)備好之后,就可以開(kāi)始編寫(xiě)demo了
單個(gè)內(nèi)容替換
短短的三行代碼,就完成了讀取,替換,保存的功能:
package com.test; import com.spire.doc.Document; import com.spire.doc.FileFormat; /** * @description: 替換word文檔中的變量 * @author: 魏一鶴 * @createDate: 2023-01-08 10:51 **/ public class FileTest3 { public static void main(String[] args) { //加載Word文檔 Document document = new Document("C:\\Users\\PC\\Desktop\\test.docx"); //使用新文本替換文檔中的指定文本 document.replace("${name}", "張三豐", false, true); //保存文檔 document.saveToFile("C:\\Users\\PC\\Desktop\\test2.docx", FileFormat.Docx_2013); } }
這時(shí)候打開(kāi)桌面生成的文件查看,${name}的變量以及被替換掉了
但是這只是單獨(dú)替換一個(gè)變量,一般一個(gè)模板里面是會(huì)有很多的變量的,這事我們需要支持批量替換變量
批量?jī)?nèi)容替換
想要實(shí)現(xiàn)批量?jī)?nèi)容替換,其實(shí)也很簡(jiǎn)單,還是拿上面舉例的模板進(jìn)行操作:
方式1
笨點(diǎn)的方式:既然我們使用的是document.replace進(jìn)行替換,那么模板里面有多少個(gè)變量,我們就寫(xiě)多少個(gè)document.replac即可:
package com.test; import com.spire.doc.Document; import com.spire.doc.FileFormat; /** * @description: 替換word文檔中的變量 * @author: 魏一鶴 * @createDate: 2023-01-08 10:51 **/ public class FileTest3 { public static void main(String[] args) { //加載Word文檔 Document document = new Document("C:\\Users\\PC\\Desktop\\test.docx"); //使用新文本替換文檔中的指定文本 document.replace("${name}", "張三豐", false, true); document.replace("${age}", "18", false, true); document.replace("${sex}", "男", false, true); //保存文檔 document.saveToFile("C:\\Users\\PC\\Desktop\\test2.docx", FileFormat.Docx_2013); } }
雖然笨,但是可行:
方式2
雖然上面的方式可行,但是維護(hù)起來(lái)比較麻煩,這時(shí)候我們可以采取這種方式:
聲明一個(gè)map,把一組組的key和value進(jìn)行保存,key就是變量, value就是模板值,然后循環(huán)map進(jìn)行替換,這樣不管多少個(gè)變量,我們都只需要在map里配置即可
package com.test; import com.spire.doc.Document; import com.spire.doc.FileFormat; import java.util.HashMap; import java.util.Set; /** * @description: 替換word文檔中的變量 * @author: 魏一鶴 * @createDate: 2023-01-08 10:51 **/ public class FileTest3 { public static void main(String[] args) { //加載Word文檔 Document document = new Document("C:\\Users\\PC\\Desktop\\test.docx"); //模板變量map HashMap<String, Object> paramsMap = new HashMap<>(); // 填充key和vaulue key=模板變量,value=替換后的值 paramsMap.put("${name}","張三豐"); paramsMap.put("${age}","18"); paramsMap.put("${sex}","男"); // 循環(huán)key for(String key:paramsMap.keySet()){ // 根據(jù)key得到value String value = paramsMap.get(key).toString(); //使用新文本替換文檔中的指定文本 也就是value替換key document.replace(key, value, false, true); } //保存文檔 document.saveToFile("C:\\Users\\PC\\Desktop\\test3.docx", FileFormat.Docx_2013); } }
再次運(yùn)行代碼,文檔里面的變量以及全部完成了替換。
總結(jié)
能夠?qū)崿F(xiàn)這樣的例子很多,我個(gè)人也花了兩天試了很多的demo,包括Apache下的poi的XWPFDocument,Java File文件流等,經(jīng)過(guò)大量的常識(shí),我個(gè)人更傾向于這種方式,不僅代碼量少,而且spire本身就是支持對(duì)于word文檔操作的,功能更多且強(qiáng)大。所以在次推薦給大家
到此這篇關(guān)于Java如何使用spire進(jìn)行word文檔的替換詳解的文章就介紹到這了,更多相關(guān)Java spire對(duì)word文檔替換內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Mybatis Integer類(lèi)型參數(shù)值為0時(shí)得到為空的解決方法
這篇文章主要介紹了Mybatis Integer類(lèi)型參數(shù)值為0時(shí)得到為空的解決方法,有需要的朋友們可以學(xué)習(xí)下。2019-08-08Java-Redis-Redisson分布式鎖的功能使用及實(shí)現(xiàn)
這篇文章主要介紹了Java-Redis-Redisson-分布式鎖的功能使用及實(shí)現(xiàn),本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-08-08mybatis如何使用Java8的日期LocalDate和LocalDateTime詳解
這篇文章主要給大家介紹了關(guān)于mybatis如何使用Java8的日期LocalDate和LocalDateTime的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。2017-09-09使用BigDecimal進(jìn)行精確運(yùn)算(實(shí)現(xiàn)加減乘除運(yùn)算)
這篇文章主要介紹了如何使用BigDecimal進(jìn)行精確運(yùn)算,最后提供了一個(gè)工具類(lèi),該工具類(lèi)提供加,減,乘,除運(yùn)算2013-11-11