Java使用Spire.Doc for Java實(shí)現(xiàn)Word自動(dòng)化插入圖片
在日常工作中,Word文檔是不可或缺的工具,而圖片作為信息傳達(dá)的重要載體,其在文檔中的插入與布局顯得尤為關(guān)鍵。當(dāng)我們需要批量處理、自動(dòng)化生成包含圖片的Word文檔時(shí),手動(dòng)操作顯然效率低下。本文將深入探討如何利用強(qiáng)大的Spire.Doc for Java庫(kù),實(shí)現(xiàn)Word文檔插入圖片的自動(dòng)化,并精細(xì)控制圖片環(huán)繞方式和圖片定位,助你輕松駕馭Java操作Word的復(fù)雜場(chǎng)景,實(shí)現(xiàn)高效Word自動(dòng)化。
1. Spire.Doc for Java庫(kù)介紹與安裝
Spire.Doc是一款功能強(qiáng)大且易于使用的Java組件,專(zhuān)為處理Word文檔而設(shè)計(jì)。它允許開(kāi)發(fā)者在Java應(yīng)用程序中創(chuàng)建、讀取、編輯、轉(zhuǎn)換和打印Word文檔,無(wú)需安裝Microsoft Word。其優(yōu)勢(shì)在于API接口豐富、性能優(yōu)越,能夠滿(mǎn)足各種復(fù)雜的文檔處理需求。
Maven依賴(lài)配置:
<repositories>
<repository>
<id>com.e-iceblue</id>
<name>e-iceblue</name>
<url>https://repo.e-iceblue.cn/repository/maven-public/</url>
</repository>
</repositories>
<dependencies>
<dependency>
<groupId>e-iceblue</groupId>
<artifactId>spire.doc</artifactId>
<version>13.11.2</version>
</dependency>
</dependencies>
2. 使用特定的環(huán)繞方式插入圖片
在Word中,圖片的文本環(huán)繞方式?jīng)Q定了圖片與周?chē)谋镜年P(guān)系。Spire.Doc for Java提供了靈活的API來(lái)設(shè)置這些環(huán)繞方式。
核心步驟:
- 加載或創(chuàng)建Word文檔。
- 獲取文檔中的某個(gè)段落或創(chuàng)建一個(gè)新段落。
- 創(chuàng)建
DocPicture對(duì)象,并加載圖片文件。 - 將
DocPicture對(duì)象添加到段落中。 - 設(shè)置圖片的環(huán)繞方式。
代碼示例:
import com.spire.doc.*;
import com.spire.doc.documents.*;
import com.spire.doc.fields.*;
public class insertImage {
public static void main(String[] args) throws Exception {
//創(chuàng)建 Document 類(lèi)的對(duì)象
Document doc = new Document();
//從磁盤(pán)載入 Word 文件
doc.loadFromFile("D:/Samples/Sample.docx");
//創(chuàng)建 DocPicture 類(lèi)的對(duì)象
DocPicture picture = new DocPicture(doc);
//從磁盤(pán)加載圖片
picture.loadImage("D:/Samples/System.png");
//設(shè)置圖片大小
picture.setWidth(75);
picture.setHeight(90);
//將圖片文本環(huán)繞方式設(shè)置為四周環(huán)繞
picture.setTextWrappingStyle( TextWrappingStyle.Square);
//將圖片插入到第二段
doc.getSections().get(0).getParagraphs().get(1).getChildObjects().insert(0,picture);
//保存文檔
doc.saveToFile("D:/javaOutput/insertImage.docx", FileFormat.Docx);
}
}
不同環(huán)繞方式的視覺(jué)效果和應(yīng)用場(chǎng)景:
- 嵌入型 (Inline) : 圖片被視為文本字符,隨文本流動(dòng)。適用于圖片與文字緊密結(jié)合,不希望圖片浮動(dòng)的情況。
- 四周型 (Square) : 文本圍繞圖片的矩形邊框。最常見(jiàn)的環(huán)繞方式,圖片與文本互不遮擋。
- 緊密型 (Tight) : 文本緊密地圍繞圖片的實(shí)際輪廓。比四周型更貼合圖片形狀,適用于不規(guī)則形狀的圖片。
- 浮于文字下方 (Behind) : 圖片位于文本下方,文本會(huì)覆蓋圖片。適用于作為背景水印或裝飾性圖片。
- 浮于文字上方 (InFrontOfText) : 圖片位于文本上方,會(huì)遮擋文本。適用于需要突出圖片,或作為浮動(dòng)元素。
- 上下型 (TopAndBottom) : 文本在圖片上方和下方,不與圖片左右兩側(cè)并排。
3. 在指定位置插入圖片
除了環(huán)繞方式,精確控制圖片在文檔中的位置也至關(guān)重要。Spire.Doc for Java允許你在段落、表格單元格甚至通過(guò)絕對(duì)坐標(biāo)來(lái)定位圖片。直接通過(guò)Paragraph.getChildObjects().insert()即可在文檔的任意位置插入圖片,如下所示:
import com.spire.doc.*;
import com.spire.doc.documents.*;
import com.spire.doc.fields.*;
public class insertImage {
public static void main(String[] args) throws Exception {
//創(chuàng)建 Document 類(lèi)的對(duì)象
Document doc = new Document();
//從磁盤(pán)加載 Word 文檔
doc.loadFromFile("D:/Samples/Sample.docx");
//創(chuàng)建 DocPicture 類(lèi)的對(duì)象
DocPicture picture = new DocPicture(doc);
//從磁盤(pán)加載圖片
picture.loadImage("D:/Samples/PDF.png");
//設(shè)置圖片的大小
picture.setWidth(75);
picture.setHeight(90);
//將圖片的文本環(huán)繞方式設(shè)置為四周環(huán)繞
picture.setTextWrappingStyle( TextWrappingStyle.Square);
//將圖片插入到第二段
doc.getSections().get(0).getParagraphs().get(2).getChildObjects().insert(0,picture);
//設(shè)置圖片的位置
picture.setHorizontalPosition(370.0F);
picture.setVerticalPosition(10.0F);
//保存文檔
doc.saveToFile("D:/javaOutput/insertImage.docx", FileFormat.Docx);
}
}
DocPicture定位屬性詳解:
setHorizontalPosition() / setVerticalPosition(): 設(shè)置圖片相對(duì)于其定位基準(zhǔn)的偏移量。setHorizontalOrigin() / setVerticalOrigin(): 設(shè)置圖片水平/垂直定位的基準(zhǔn)點(diǎn),可選值包括Page(頁(yè)面)、Column(列)、Margin(頁(yè)邊距)、Paragraph(段落)等。精確的定位通常需要選擇Page作為基準(zhǔn)。
4. 常見(jiàn)問(wèn)題解答
圖片路徑問(wèn)題: 確?;騦oadImage()方法中提供的圖片路徑是正確的,可以是相對(duì)路徑或絕對(duì)路徑。對(duì)于Web應(yīng)用,可能需要將圖片轉(zhuǎn)換為字節(jié)流加載。
圖片大小調(diào)整: 通過(guò)picture.setWidth()和picture.setHeight()可以設(shè)置圖片的尺寸。Spire.Doc也會(huì)自動(dòng)根據(jù)圖片原始尺寸進(jìn)行一定程度的縮放,但手動(dòng)設(shè)置可以更精確控制。
圖片質(zhì)量: 插入的圖片質(zhì)量取決于原始圖片。如果圖片過(guò)大,可能導(dǎo)致文檔文件體積增大,可以考慮在插入前對(duì)圖片進(jìn)行壓縮處理。
性能優(yōu)化: 批量插入大量圖片時(shí),可能會(huì)影響性能。可以考慮分批處理,或優(yōu)化圖片加載和文檔保存邏輯。對(duì)于大型文檔,Spire.Doc提供了分段處理等機(jī)制來(lái)提高效率。
不支持的圖片格式: 確保插入的圖片格式是Word支持的常見(jiàn)格式(如PNG, JPG, BMP, GIF)。
文本環(huán)繞與定位沖突: 當(dāng)設(shè)置了非嵌入型環(huán)繞方式后,圖片會(huì)脫離文本流,此時(shí)可以通過(guò)setHorizontalPosition和setVerticalPosition進(jìn)行精確控制。
5.知識(shí)擴(kuò)展
下面我們來(lái)看看java如何使用spire.doc實(shí)現(xiàn)插入文字、圖片、表格、富文本吧
示例代碼
import com.example.utils.DocxUtil;
import com.spire.doc.*;
import com.spire.doc.documents.*;
import com.spire.doc.fields.DocPicture;
import java.awt.*;
import java.util.ArrayList;
import java.util.List;
/**
* TODO
*
* @Description
* @Author WL
* @Date 2024/2/28
**/
public class DocxAddParagraphTest {
public static void main(String[] args) {
//創(chuàng)建document對(duì)象
Document document = new Document("D:\\temp\\document-blank.docx");
//獲取最后一個(gè)section
Section newSec = document.getLastSection();
//添加文本
Paragraph textParagtaph = newSec.addParagraph();
//設(shè)置文本格式
ParagraphStyle styleContent = new ParagraphStyle(document);
styleContent.setName("codeStyle");
styleContent.getCharacterFormat().setFontName("宋體");
styleContent.getCharacterFormat().setFontSize(10f);
styleContent.getParagraphFormat().setHorizontalAlignment(HorizontalAlignment.Left);
document.getStyles().add(styleContent);
textParagtaph.applyStyle("codeStyle");
textParagtaph.appendText("第01號(hào)");
Paragraph text1Paragtaph = newSec.addParagraph();
//設(shè)置文本格式
ParagraphStyle styleTitle = new ParagraphStyle(document);
//設(shè)置樣式名稱(chēng)
styleTitle.setName("titleStyle");
//設(shè)置字體
styleTitle.getCharacterFormat().setFontName("宋體");
//設(shè)置字體大小
styleTitle.getCharacterFormat().setFontSize(20f);
//設(shè)置文本顏色
styleTitle.getCharacterFormat().setTextColor(Color.CYAN);
//設(shè)置文本居中
styleTitle.getParagraphFormat().setHorizontalAlignment(HorizontalAlignment.Center);
//添加樣式到文檔
document.getStyles().add(styleTitle);
//應(yīng)用樣式
text1Paragtaph.applyStyle("titleStyle");
//添加文本
text1Paragtaph.appendText("關(guān)于******公告");
//添加文本
Paragraph textPeoParagtaph = newSec.addParagraph();
//設(shè)置文本格式
ParagraphStyle stylePeoContent = new ParagraphStyle(document);
stylePeoContent.setName("peoStyle");
stylePeoContent.getCharacterFormat().setFontName("宋體");
stylePeoContent.getCharacterFormat().setFontSize(12f);
stylePeoContent.getParagraphFormat().setHorizontalAlignment(HorizontalAlignment.Left);
document.getStyles().add(stylePeoContent);
textPeoParagtaph.applyStyle("peoStyle");
textPeoParagtaph.appendText("姓名:姜XX\t\t\t手機(jī)號(hào)碼:13866669999");
//添加文本
Paragraph textAddParagtaph = newSec.addParagraph();
//設(shè)置文本格式
ParagraphStyle styleAddContent = new ParagraphStyle(document);
styleAddContent.setName("addStyle");
styleAddContent.getCharacterFormat().setFontName("宋體");
styleAddContent.getCharacterFormat().setFontSize(12f);
styleAddContent.getParagraphFormat().setHorizontalAlignment(HorizontalAlignment.Left);
document.getStyles().add(styleAddContent);
textAddParagtaph.applyStyle("addStyle");
textAddParagtaph.getFormat().setFirstLineIndent(30f);
textAddParagtaph.appendText("聯(lián)系地址:湖北武漢");
//添加表格
List<String> headerList = new ArrayList<>();
headerList.add("姓名");
headerList.add("電話");
headerList.add("地址");
List<List<Object>> dataList = new ArrayList<>();
List<Object> data1 = new ArrayList<>();
data1.add("姜XX");
data1.add("18899996666");
data1.add("浙江");
dataList.add(data1);
List<Object> data2 = new ArrayList<>();
data2.add("tj");
data2.add("15549490011");
data2.add("杭州");
dataList.add(data2);
List<Object> data3 = new ArrayList<>();
data3.add("趙XX");
data3.add("135****713");
data3.add("武漢");
dataList.add(data3);
String tableTitle = "表格標(biāo)題";
DocxUtil.createTable(newSec, headerList, dataList, tableTitle);
//添加圖片
// 創(chuàng)建 DocPicture 類(lèi)的對(duì)象
DocPicture picture = new DocPicture(document);
// 從磁盤(pán)加載圖片
String images = "D:\\temp\\123.jpg";
picture.loadImage(images);
// 設(shè)置圖片大小
picture.setWidth(180); //示例:80
picture.setHeight(180);//示例:50
picture.setHorizontalPosition(110); //示例:110.0F 水平位置
picture.setVerticalPosition(220); //示例:110.0F 垂直位置
Paragraph picParagraph = newSec.addParagraph();
picParagraph.getChildObjects().add(picture);
//添加圖片
// 創(chuàng)建 DocPicture 類(lèi)的對(duì)象
DocPicture picture1 = new DocPicture(document);
// 從磁盤(pán)加載圖片
String images1 = "D:\\temp\\321.jpg";
picture1.loadImage(images1);
// 設(shè)置圖片大小
picture1.setWidth(500); //示例:80
picture1.setHeight(180);//示例:50
picture1.setHorizontalPosition(110); //示例:110.0F 水平位置
picture1.setVerticalPosition(220); //示例:110.0F 垂直位置
Paragraph picParagraph1 = newSec.addParagraph();
picParagraph1.getChildObjects().add(picture1);
//添加富文本
Paragraph tempSectionContentParagraph = newSec.addParagraph();
String htmlContent = "<p>Spire.Doc for Java 是一款專(zhuān)業(yè)的 Java Word 組件,開(kāi)發(fā)人員使用它可以輕松地將 Word 文檔創(chuàng)建、讀取、編輯、轉(zhuǎn)換和打印等功能集成到自己的 Java 應(yīng)用程序中。作為一款完全獨(dú)立的組件,Spire.Doc for Java 的運(yùn)行環(huán)境無(wú)需安裝 Microsoft Office。</p>
<p>Spire.Doc for Java 能執(zhí)行多種 Word 文檔處理任務(wù),包括生成、讀取、轉(zhuǎn)換和打印 Word 文檔,插入圖片,添加頁(yè)眉和頁(yè)腳,創(chuàng)建表格,添加表單域和郵件合并域,添加書(shū)簽,添加文本和圖片水印,設(shè)置背景顏色和背景圖片,添加腳注和尾注,添加超鏈接,加密和解密 Word 文檔,添加批注,添加形狀等。</p>
<p><img src="" alt="" width="75" height="75" /></p>";
htmlContent=htmlContent+"<p> </p>";
tempSectionContentParagraph.appendHTML(htmlContent);
//添加文本
Paragraph text3Paragtaph = newSec.addParagraph();
ParagraphStyle styleContent3 = new ParagraphStyle(document);
styleContent3.setName("codeStyle3");
styleContent3.getCharacterFormat().setFontName("宋體");
styleContent3.getCharacterFormat().setFontSize(15f);
document.getStyles().add(styleContent3);
text3Paragtaph.applyStyle("codeStyle3");
text3Paragtaph.appendText("第02號(hào)");
Paragraph text4Paragtaph = newSec.addParagraph();
//設(shè)置文本格式
ParagraphStyle styleTitle4 = new ParagraphStyle(document);
styleTitle4.setName("titleStyle4");
styleTitle4.getCharacterFormat().setFontName("宋體");
styleTitle4.getCharacterFormat().setFontSize(25f);
styleTitle4.getCharacterFormat().setTextColor(Color.ORANGE);
styleTitle4.getParagraphFormat().setHorizontalAlignment(HorizontalAlignment.Center);
document.getStyles().add(styleTitle4);
text4Paragtaph.applyStyle("titleStyle4");
text4Paragtaph.appendText("關(guān)于***************************Text");
DocxUtil.insertHeaderAndFooter(newSec);
document.saveToFile("D:\\temp\\documentNew.docx", FileFormat.Docx_2013);
}
}使用到的工具
import com.spire.doc.*;
import com.spire.doc.documents.*;
import com.spire.doc.fields.TextRange;
import java.awt.*;
import java.security.Timestamp;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.List;
/**
* TODO
*
* @Description
* @Author WL
* @Date 2024/2/28
**/
public class DocxUtil {
// 動(dòng)態(tài)創(chuàng)建表格
public static void createTable(Section section, List<String> header, List<List<Object>> data, String title) {
//添加表格
Table table = section.addTable(true);
//設(shè)置表格的行數(shù)和列數(shù)
table.resetCells(data.size()+ 2, header.size());
//設(shè)置第一行作為表格的表頭并添加數(shù)據(jù)
TableRow row = table.getRows().get(1);
row.isHeader(true);
row.setHeight(40);
row.setHeightType(TableRowHeightType.Exactly);
TableRow row3 = table.getRows().get(0);
row3.isHeader(true);
row3.setHeight(60);
row3.setHeightType(TableRowHeightType.Exactly);
row3.getCells().get(0).getCellFormat().setVerticalAlignment(VerticalAlignment.Middle);
table.applyHorizontalMerge(0, 0, header.size() - 1);
Paragraph p1 = row3.getCells().get(0).addParagraph();
p1.getFormat().setHorizontalAlignment(HorizontalAlignment.Center);
TextRange range3 = p1.appendText(title);
range3.getCharacterFormat().setFontName("仿宋_GB2312");
range3.getCharacterFormat().setFontSize(12f);
range3.getCharacterFormat().setTextColor(Color.black);
range3.getCharacterFormat().setBold(true);
for (int i = 0; i < header.size(); i++) {
row.getCells().get(i).getCellFormat().setVerticalAlignment(VerticalAlignment.Middle);
Paragraph p = row.getCells().get(i).addParagraph();
p.getFormat().setHorizontalAlignment(HorizontalAlignment.Center);
TextRange range1 = p.appendText(header.get(i));
range1.getCharacterFormat().setTextColor(Color.black);
range1.getCharacterFormat().setFontName("仿宋_GB2312");
range1.getCharacterFormat().setFontSize(12f);
range1.getCharacterFormat().setBold(true);
}
//添加數(shù)據(jù)到剩余行
try{
for (int r = 0; r < data.size(); r++) {
TableRow dataRow = table.getRows().get(r + 2);
dataRow.setHeight(25);
dataRow.setHeightType(TableRowHeightType.Exactly);
dataRow.getRowFormat().setBackColor(Color.white);
for (int c = 0; c < data.get(r).size(); c++) {
dataRow.getCells().get(c).getCellFormat().setVerticalAlignment(VerticalAlignment.Middle);
String s = "";
if (data.get(r).get(c) instanceof Timestamp) {
SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");//定義格式,不顯示毫秒
s = df.format((Timestamp) (data.get(r).get(c)));
} else if (data.get(r).get(c) instanceof Date) {
SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");//定義格式,不顯示毫秒
s = df.format((Date) (data.get(r).get(c)));
} else if (data.get(r).get(c) == null) {
s = "";
} else {
s = data.get(r).get(c).toString();
}
TextRange range2 = dataRow.getCells().get(c).addParagraph().appendText(s);
range2.getCharacterFormat().setFontName("仿宋_GB2312");
range2.getCharacterFormat().setFontSize(10f);
}
}
}catch (Exception e){
e.getMessage();
// log.info("插入數(shù)據(jù)有異常");
}
section.addParagraph();
}
//生成頁(yè)眉和頁(yè)腳
public static void insertHeaderAndFooter(Section section) {
//分別獲取section的頁(yè)眉頁(yè)腳
HeaderFooter header = section.getHeadersFooters().getHeader();
HeaderFooter footer = section.getHeadersFooters().getFooter();
//添加段落到頁(yè)眉
Paragraph headerParagraph = header.addParagraph();
//添加文字到頁(yè)眉的段落
TextRange text = headerParagraph.appendText("頁(yè)眉測(cè)試");
text.getCharacterFormat().setFontName("仿宋_GB2312");
text.getCharacterFormat().setFontSize(10);
text.getCharacterFormat().setItalic(true);
headerParagraph.getFormat().setHorizontalAlignment(HorizontalAlignment.Left);
//設(shè)置頁(yè)眉段落的底部邊線樣式
headerParagraph.getFormat().getBorders().getBottom().setBorderType(BorderStyle.Single);
headerParagraph.getFormat().getBorders().getBottom().setLineWidth(1f);
//添加段落到頁(yè)腳
Paragraph footerParagraph = footer.addParagraph();
//添加Field_Page和Field_Num_Pages域到頁(yè)腳段落,用于顯示當(dāng)前頁(yè)碼和總頁(yè)數(shù)
footerParagraph.appendField("page number", FieldType.Field_Page);
footerParagraph.appendText("/");
footerParagraph.appendField("number of pages", FieldType.Field_Num_Pages);
footerParagraph.getFormat().setHorizontalAlignment(HorizontalAlignment.Right);
//設(shè)置頁(yè)腳段落的頂部邊線樣式
footerParagraph.getFormat().getBorders().getTop().setBorderType(BorderStyle.Single);
footerParagraph.getFormat().getBorders().getTop().setLineWidth(1f);
}
}6.總結(jié)
通過(guò)Spire.Doc for Java庫(kù),我們不僅能夠輕松實(shí)現(xiàn)Word文檔插入圖片的基礎(chǔ)功能,更能通過(guò)精細(xì)的API控制圖片環(huán)繞方式和圖片定位,從而滿(mǎn)足復(fù)雜的文檔自動(dòng)化需求。無(wú)論是生成報(bào)告、合同,還是批量處理各類(lèi)文檔,Spire.Doc都提供了強(qiáng)大的支持。掌握這些技巧,將極大地提升你的Java操作Word效率,開(kāi)啟Word自動(dòng)化的新篇章,期待你在實(shí)際項(xiàng)目中探索更多可能!
到此這篇關(guān)于Java使用Spire.Doc for Java實(shí)現(xiàn)Word自動(dòng)化插入圖片的文章就介紹到這了,更多相關(guān)Java Word插入圖片內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
mybatis映射和實(shí)際類(lèi)型不一致的問(wèn)題
這篇文章主要介紹了mybatis映射和實(shí)際類(lèi)型不一致的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-11-11
Mybatis-plus批量去重插入ON DUPLICATE key update使用方式
這篇文章主要介紹了Mybatis-plus批量去重插入ON DUPLICATE key update使用方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-12-12
創(chuàng)建一個(gè)Java的不可變對(duì)象
這篇文章主要介紹了創(chuàng)建一個(gè)Java的不可變對(duì)象,一個(gè)類(lèi)的對(duì)象在通過(guò)構(gòu)造方法創(chuàng)建后如果狀態(tài)不會(huì)再被改變,那么它就是一個(gè)不可變(immutable)類(lèi)。它的所有成員變量的賦值僅在構(gòu)造方法中完成,不會(huì)提供任何 setter 方法供外部類(lèi)去修改,需要的朋友可以參考下2021-11-11
JAVA實(shí)現(xiàn)掃描線算法(超詳細(xì))
掃描線算法就是從Ymin開(kāi)始掃描,然后構(gòu)建出NET,之后根據(jù)NET建立AET。接下來(lái)本文通過(guò)代碼給大家介紹JAVA實(shí)現(xiàn)掃描線算法,感興趣的朋友一起看看吧2019-10-10
idea編譯時(shí)不提示任何錯(cuò)誤信息的問(wèn)題及解決
這篇文章主要介紹了idea編譯時(shí)不提示任何錯(cuò)誤信息的問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-12-12

