【環境配置】

本文將通過Java程式程式碼來展示如何來獲取Word批註所標註的文字和圖片。這裡使用的Word Jar包工具是Free Spire.Doc for Java,在pom.xml中按如下步驟配置內容:

內容如下:

<repositories>
<repository>
<id>com.e-iceblue</id>
<url>http://repo.e-iceblue.cn/repository/maven-public/</url>
</repository>
</repositories>
<dependencies>
<dependency>
<groupId> e-iceblue </groupId>
<artifactId>spire.doc.free</artifactId>
<version>3.9.0</version>
</dependency>
</dependencies>

【測試文件】

測試文件如圖,包含對文字和圖片標記的批註:

【Java程式碼】

import com.spire.doc.*;
import com.spire.doc.documents.CommentMark;
import com.spire.doc.documents.Paragraph;
import com.spire.doc.fields.Comment;
import com.spire.doc.fields.DocPicture;
import com.spire.doc.fields.TextRange; import javax.imageio.ImageIO;
import java.awt.image.RenderedImage;
import java.io.File;
import java.io.IOException;
import java.util.ArrayList; public class GetMarkedTextAndImg {
public static void main(String[] args)throws IOException {
//載入Word文件
Document doc = new Document();
doc.loadFromFile("inputfile.docx"); //獲取文件中批註
for(int a = 0;a<doc.getComments().getCount();a++)
{
Comment comment = doc.getComments().get(a);
//獲取批註的開始標記和結束標記
Paragraph para = comment.getOwnerParagraph();
CommentMark start = comment.getCommentMarkStart();
CommentMark end = comment.getCommentMarkEnd(); //獲取開始標記和結束標記在段落中的索引
int indexOfStart = para.getChildObjects().indexOf(start);
int indexOfEnd = para.getChildObjects().indexOf(end); String markedText = "";
ArrayList images = new ArrayList();
//根據索引獲取批註的開始標記和結束標記之間的文字、圖片
for (int i = indexOfStart + 1; i < indexOfEnd; i++)
{
if (para.getChildObjects().get(i) instanceof TextRange)
{
TextRange range = (TextRange) para.getChildObjects().get(i);
markedText += range.getText();
} if (para.getChildObjects().get(i) instanceof DocPicture)
{
DocPicture picture = (DocPicture) para.getChildObjects().get(i);
images.add(picture.getImage());
} } //列印批註標記的文字
System.out.println(markedText); //提取批註標記的圖片
for (int z = 0; z< images.size(); z++)
{
File file = new File(String.format("MarkedImg.png", z));
ImageIO.write((RenderedImage) images.get(z), "PNG", file);
}
} }
}

批註標記的文字讀取結果:

批註標記的圖片:

另推薦閱讀:

Java 新增、回覆、修改(替換)、刪除Word批註

Java 給Word指定字串新增批註

Java 讀取Word批註中的文字和圖片

 
 

—End—