Java入门到实战之Java实战 | Java读取Word,包含表格!
小职 2021-03-27 来源 :JAVA日知录 阅读 407 评论 0

摘要:本文主要介绍了Java入门到实战之Java实战 | Java读取Word,包含表格,通过具体的内容向大家展现,希望对大家Java开发的学习有所帮助。

本文主要介绍了Java入门到实战之Java实战 | Java读取Word,包含表格,通过具体的内容向大家展现,希望对大家Java开发的学习有所帮助。

Java入门到实战之Java实战 | 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个问题:

 

需要分别处理两种格式docx、docPOI使用不同的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>//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入门到实战之Java实战 | Java读取Word,包含表格!

本文由 @小职 发布于职坐标。未经许可,禁止转载。
喜欢 | 0 不喜欢 | 0
看完这篇文章有何感觉?已经有0人表态,0%的人喜欢 快给朋友分享吧~
评论(0)
后参与评论

您输入的评论内容中包含违禁敏感词

我知道了

助您圆梦职场 匹配合适岗位
验证码手机号,获得海同独家IT培训资料
选择就业方向:
人工智能物联网
大数据开发/分析
人工智能Python
Java全栈开发
WEB前端+H5

请输入正确的手机号码

请输入正确的验证码

获取验证码

您今天的短信下发次数太多了,明天再试试吧!

提交

我们会在第一时间安排职业规划师联系您!

您也可以联系我们的职业规划师咨询:

小职老师的微信号:z_zhizuobiao
小职老师的微信号:z_zhizuobiao

版权所有 职坐标-一站式IT培训就业服务领导者 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
 沪公网安备 31011502005948号    

©2015 www.zhizuobiao.com All Rights Reserved

208小时内训课程