中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何用JAVA讀取WORD包含表格

發布時間:2021-10-18 09:30:04 來源:億速云 閱讀:142 作者:柒染 欄目:編程語言

本篇文章為大家展示了如何用JAVA讀取WORD包含表格,內容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。

業務需求

我們有這樣一個需求,需要抽取出WORD文檔中的內容,然后組裝成特定的json格式發送給第三方引擎接口,輸入協議如下:

{
    "tables": [
        {
            "cells": [
                {
                    "col": 1,
                    "row_span": 1,
                    "row": 1,
                    "col_span": 1,
                    "content": "車輛名稱"                }
            ],
            "id": 0,
            "row_num": 2
        }
    ],
    "paragraps": [
        {
            "para_id": 1,
            "content": "Hello,JAVA日知錄"        }
    ]
}

這個輸入格式一看就是需要我們分段落和表格讀取word中的內容,既然需求已定,那就直接開始動手寫代碼吧。

基于POI實現

把 “java如何讀取word” 拿到百度去搜索,答案基本都是利用POI來實現。當然利用POI確實可以實現按段落和表格提取出內容并組裝成上述格式,但是在實踐過程中有下面2個問題:

  • 需要分別處理兩種格式 docxdocPOI使用不同的API來讀取docx和doc,所以讀取邏輯我們需要編寫兩次。
     

  • POI讀取doc的段落時會把表格的內容也讀取出來 這個問題比較坑,poi有單獨的方法讀取文檔中所有表格,但是在讀取doc格式段落文檔的時候會把表格內容也讀取出來,所以我們需要用如下方法排除掉表格:

//讀取doc
HWPFDocument doc = new HWPFDocument(stream);
Range range = doc.getRange();

//讀取段落
int num = range.numParagraphs();
Paragraph para;for (int i=0; i<num; i++) {
    para = range.getParagraph(i);
    //排除表格內容
    if (!para.isInTable()) {
        System.out.println(para.text());
    }
}

考慮以上兩種原因,我們最后并沒有采取POI來實現word內容提取功能,而是采用第二種方法,即利用 Spire.Doc for Java 來實現。

Spire.Doc for Java

Spire.Doc for Java 是一款專業的 Java Word 組件,開發人員使用它可以輕松地將 Word 文檔創建、讀取、編輯、轉換和打印等功能集成到自己的 Java 應用程序中。
作為一款完全獨立的組件,Spire.Doc for Java 的運行環境無需安裝 Microsoft Office。官網地址是 https://www.e-iceblue.cn/,我們項目中使用的開源免費版。

  • 首先我們修改maven倉庫地址

<repositories>
    <repository>
        <id>com.e-iceblue</id>
        <url>http://repo.e-iceblue.com/nexus/content/groups/public/</url>
    </repository>
</repositories>
  • 引入對應的jar包

<dependency>
    <groupId>e-iceblue</groupId>
    <artifactId>spire.doc.free</artifactId>
    <version>3.9.0</version>
</dependency>
  • 讀取word,這里展示的是測試類

public class SpireApplication {

    public static void main(String[] args) {
        String path = "D:\\testDoc22.doc";
        spireParaghDoc(path);
        spireForTableOfDoc(path); 
    }

    //讀取段落
    public static void spireParaghDoc(String path) {
        Document doc = new Document(path);
        for (int i = 0; i < doc.getSections().getCount(); i++) {
            Section section = doc.getSections().get(i);
            for (int j = 0; j < section.getParagraphs().getCount(); j++) {
                Paragraph paragraph = section.getParagraphs().get(j);
                System.out.println(paragraph.getText());
            }
        }
    }

    //讀取表格
    public static void spireForTableOfDoc(String path) {
        Document doc = new Document(path);
        for (int i = 0; i < doc.getSections().getCount(); i++) {
            Section section = doc.getSections().get(i);
            for (int j = 0; j < section.getBody().getChildObjects().getCount(); j++) {
                DocumentObject obj = section.getBody().getChildObjects().get(j);
                if (obj.getDocumentObjectType() == DocumentObjectType.Table) {
                    Table table = (Table) obj;
                    for (int k = 0; k < table.getRows().getCount(); k++) {
                        TableRow rows = table.getRows().get(k);
                        for (int p = 0; p < rows.getCells().getCount(); p++) {
                            for (int h = 0; h < rows.getCells().get(p).getParagraphs().getCount(); h++) {
                                Paragraph f = rows.getCells().get(p).getParagraphs().get(h);
                                System.out.println(f.getText());
                            }
                        }
                    }
                }
            }
        }
    }

}

通過上面代碼我們就可以按段落和表格讀取WORD中的內容,而后根據系統業務要求的格式進行封裝即可。

上述內容就是如何用JAVA讀取WORD包含表格,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

德清县| 罗山县| 顺义区| 德安县| 鄢陵县| 金堂县| 滨州市| 榆树市| 临邑县| 调兵山市| 河间市| 久治县| 沅陵县| 佛教| 应城市| 昌江| 成安县| 鄄城县| 衡水市| 淮阳县| 绿春县| 无锡市| 万州区| 麻栗坡县| 通河县| 南川市| 措勤县| 酉阳| 嘉兴市| 上高县| 建瓯市| 溧阳市| 济阳县| 承德县| 大厂| 彝良县| 肇庆市| 常熟市| 渭南市| 泰州市| 正宁县|