Java 獲取Word批註所標記的文字和圖片

iceblue發表於2021-07-22

【環境配置】

本文將通過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—

 

相關文章