实战 | JAVA读取WORD,包含表格。

简介: 我们有这样一个需求,需要抽取出WORD文档中的内容,然后组装成特定的json格式发送给第三方引擎接口

不能每天都发鸡汤呀,今天分享一篇开发实战。


业务需求


我们有这样一个需求,需要抽取出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格式段落文档的时候会把表格内容也读取出来,所以我们需要用如下方法排除掉表格:


//读取docHWPFDocumentdoc=newHWPFDocument(stream);
Rangerange=doc.getRange();
//读取段落intnum=range.numParagraphs();
Paragraphpara;
for (inti=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,这里展示的是测试类


publicclassSpireApplication {
publicstaticvoidmain(String[] args) {
Stringpath="D:\\testDoc22.doc";
spireParaghDoc(path);
spireForTableOfDoc(path); 
    }
//读取段落publicstaticvoidspireParaghDoc(Stringpath) {
Documentdoc=newDocument(path);
for (inti=0; i<doc.getSections().getCount(); i++) {
Sectionp=doc.getSections().get(i);
for (intj=0; j<p.getParagraphs().getCount(); j++) {
Paragraphparagraph=p.getParagraphs().get(j);
System.out.println(paragraph.getText());
            }
        }
    }
//读取表格publicstaticvoidspireForTableOfDoc(Stringpath) {
Documentdoc=newDocument(path);
for (inti=0; i<doc.getSections().getCount(); i++) {
Sectionp=doc.getSections().get(i);
for (intj=0; j<p.getBody().getChildObjects().getCount(); j++) {
DocumentObjectobj=p.getBody().getChildObjects().get(j);
if (obj.getDocumentObjectType() ==DocumentObjectType.Table) {
Tabletable= (Table) obj;
for (intk=0; k<table.getRows().getCount(); k++) {
TableRowrows=table.getRows().get(k);
for (intp=0; p<rows.getCells().getCount(); p++) {
for (inth=0; h<rows.getCells().get(p).getParagraphs().getCount(); h++) {
Paragraphf=rows.getCells().get(p).getParagraphs().get(h);
System.out.println(f.getText());
                            }
                        }
                    }
                }
            }
        }
    }
}


通过上面代码我们就可以按段落和表格读取WORD中的内容,而后根据系统业务要求的格式进行封装即可。


以上,希望对你有所帮助!

目录
相关文章
|
存储 SQL 分布式计算
Flink - 读取 Parquet 文件 By Scala / Java
parquet 文件常见与 Flink、Spark、Hive、Streamin、MapReduce 等大数据场景,通过列式存储和元数据存储的方式实现了高效的数据存储与检索,下面介绍 Flink 场景下如何读取 Parquet。
1647 0
Flink - 读取 Parquet 文件 By Scala / Java
|
Java Linux API
Java读取Excel表格中的数据
Java读取Excel表格中的数据
Java读取Excel表格中的数据
|
缓存 JSON Java
java 实现读取txt文件,反射创建对象,android 手机缓存文件目录
java 实现读取txt文件,反射创建对象,android 手机缓存文件目录
467 1
java 实现读取txt文件,反射创建对象,android 手机缓存文件目录
JAVA远程读取服务器文件
JAVA远程读取服务器文件
744 1
Java-读取本地txt文件的问题
Java-读取本地txt文件的问题
218 0
|
Java 数据库
java语言读取Excel文件信息
最近项目中有一个表信息过大,需要手动删除,因为信息量比较大手动删除较为麻烦,所以采用使用excel读取数据的方式,然后操作数据库删除数据,其实只要是想要从Excel中获取信息都可以使用这种方式进行操作Excel,代码很简单。
212 0
|
Java 数据库连接 数据库
Java编程:MyBatis读取数据库数据
Java编程:MyBatis读取数据库数据
258 0
Java编程:MyBatis读取数据库数据
|
XML 存储 Java
java积累——dom4j读取xml文件
java积累——dom4j读取xml文件
284 0
|
消息中间件 Java Kafka
Java模拟读取本地数据到Flink集成的Kafka并消费数据
Java模拟读取本地数据到Flink集成的Kafka并消费数据
242 0