国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

實(shí)戰(zhàn) | Java讀取Word,包含表格!

開發(fā) 后端
Spire.Doc for Java 是一款專業(yè)的 Java Word 組件,開發(fā)人員使用它可以輕松地將 Word 文檔創(chuàng)建、讀取、編輯、轉(zhuǎn)換和打印等功能集成到自己的 Java 應(yīng)用程序中。

[[387140]]

本文轉(zhuǎn)載自微信公眾號(hào)「JAVA日知錄」,作者單一色調(diào)。轉(zhuǎn)載本文請(qǐng)聯(lián)系JAVA日知錄公眾號(hào)。

不能每天都發(fā)雞湯呀,今天分享一篇開發(fā)實(shí)戰(zhàn)。

業(yè)務(wù)需求

我們有這樣一個(gè)需求,需要抽取出WORD文檔中的內(nèi)容,然后組裝成特定的json格式發(fā)送給第三方引擎接口,輸入?yún)f(xié)議如下:

  1.     "tables": [ 
  2.         { 
  3.             "cells": [ 
  4.                 { 
  5.                     "col": 1, 
  6.                     "row_span": 1, 
  7.                     "row": 1, 
  8.                     "col_span": 1, 
  9.                     "content""車輛名稱" 
  10.                 } 
  11.             ], 
  12.             "id": 0, 
  13.             "row_num": 2 
  14.         } 
  15.     ], 
  16.     "paragraps": [ 
  17.         { 
  18.             "para_id": 1, 
  19.             "content""Hello,JAVA日知錄" 
  20.         } 
  21.     ] 

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

基于POI實(shí)現(xiàn)

把 “java如何讀取word” 拿到百度去搜索,答案基本都是利用POI來(lái)實(shí)現(xiàn)。當(dāng)然利用POI確實(shí)可以實(shí)現(xiàn)按段落和表格提取出內(nèi)容并組裝成上述格式,但是在實(shí)踐過(guò)程中有下面2個(gè)問(wèn)題:

需要分別處理兩種格式docx、docPOI使用不同的API來(lái)讀取docx和doc,所以讀取邏輯我們需要編寫兩次。

POI讀取doc的段落時(shí)會(huì)把表格的內(nèi)容也讀取出來(lái) 這個(gè)問(wèn)題比較坑,poi有單獨(dú)的方法讀取文檔中所有表格,但是在讀取doc格式段落文檔的時(shí)候會(huì)把表格內(nèi)容也讀取出來(lái),所以我們需要用如下方法排除掉表格:

  1. //讀取doc 
  2. HWPFDocument doc = new HWPFDocument(stream); 
  3. Range range = doc.getRange(); 
  4.  
  5. //讀取段落 
  6. int num = range.numParagraphs(); 
  7. Paragraph para; 
  8. for (int i=0; i<num; i++) { 
  9.     para = range.getParagraph(i); 
  10.     //排除表格內(nèi)容 
  11.     if (!para.isInTable()) { 
  12.         System.out.println(para.text()); 
  13.     } 

考慮以上兩種原因,我們最后并沒(méi)有采取POI來(lái)實(shí)現(xiàn)word內(nèi)容提取功能,而是采用第二種方法,即利用 Spire.Doc for Java 來(lái)實(shí)現(xiàn)。

Spire.Doc for Java

Spire.Doc for Java 是一款專業(yè)的 Java Word 組件,開發(fā)人員使用它可以輕松地將 Word 文檔創(chuàng)建、讀取、編輯、轉(zhuǎn)換和打印等功能集成到自己的 Java 應(yīng)用程序中。

作為一款完全獨(dú)立的組件,Spire.Doc for Java 的運(yùn)行環(huán)境無(wú)需安裝 Microsoft Office。官網(wǎng)地址是 https://www.e-iceblue.cn/,我們項(xiàng)目中使用的開源免費(fèi)版。

首先我們修改maven倉(cāng)庫(kù)地址

  1. <repositories> 
  2.     <repository> 
  3.         <id>com.e-iceblue</id> 
  4.         <url>http://repo.e-iceblue.com/nexus/content/groups/public/</url> 
  5.     </repository> 
  6. </repositories> 

 

 

引入對(duì)應(yīng)的jar包

  1. <dependency> 
  2.     <groupId>e-iceblue</groupId> 
  3.     <artifactId>spire.doc.free</artifactId> 
  4.     <version>3.9.0</version> 
  5. </dependency> 

 

讀取word,這里展示的是測(cè)試類

  1. public class SpireApplication { 
  2.  
  3.     public static void main(String[] args) { 
  4.         String path = "D:\\testDoc22.doc"
  5.         spireParaghDoc(path); 
  6.         spireForTableOfDoc(path);  
  7.     } 
  8.  
  9.     //讀取段落 
  10.     public static void spireParaghDoc(String path) { 
  11.         Document doc = new Document(path); 
  12.         for (int i = 0; i < doc.getSections().getCount(); i++) { 
  13.             Section section = doc.getSections().get(i); 
  14.             for (int j = 0; j < section.getParagraphs().getCount(); j++) { 
  15.                 Paragraph paragraph = section.getParagraphs().get(j); 
  16.                 System.out.println(paragraph.getText()); 
  17.             } 
  18.         } 
  19.     } 
  20.  
  21.     //讀取表格 
  22.     public static void spireForTableOfDoc(String path) { 
  23.         Document doc = new Document(path); 
  24.         for (int i = 0; i < doc.getSections().getCount(); i++) { 
  25.             Section section = doc.getSections().get(i); 
  26.             for (int j = 0; j < section.getBody().getChildObjects().getCount(); j++) { 
  27.                 DocumentObject obj = section.getBody().getChildObjects().get(j); 
  28.                 if (obj.getDocumentObjectType() == DocumentObjectType.Table) { 
  29.                     Table table = (Table) obj; 
  30.                     for (int k = 0; k < table.getRows().getCount(); k++) { 
  31.                         TableRow rows = table.getRows().get(k); 
  32.                         for (int p = 0; p < rows.getCells().getCount(); p++) { 
  33.                             for (int h = 0; h < rows.getCells().get(p).getParagraphs().getCount(); h++) { 
  34.                                 Paragraph f = rows.getCells().get(p).getParagraphs().get(h); 
  35.                                 System.out.println(f.getText()); 
  36.                             } 
  37.                         } 
  38.                     } 
  39.                 } 
  40.             } 
  41.         } 
  42.     } 
  43.  

 

通過(guò)上面代碼我們就可以按段落和表格讀取WORD中的內(nèi)容,而后根據(jù)系統(tǒng)業(yè)務(wù)要求的格式進(jìn)行封裝即可。

 

責(zé)任編輯:武曉燕 來(lái)源: JAVA日知錄
相關(guān)推薦

2021-12-14 07:40:08

Excel自動(dòng)化辦公

2021-12-28 09:24:49

Python郵件Word

2009-08-19 10:46:48

C#操作Word表格

2009-08-19 10:42:08

C#操作Word表格

2009-09-01 11:25:08

C#讀取Word文件

2009-09-01 11:21:02

C#讀取word內(nèi)容

2009-08-28 17:34:14

讀取word文檔

2009-09-01 13:10:39

C#讀取Word

2020-08-19 17:14:26

Python數(shù)據(jù)函數(shù)

2009-08-28 17:46:18

C#讀取Word文檔

2025-02-12 00:35:24

WinForm框架工具

2025-09-28 04:00:00

JavaMarkdownWord

2020-04-13 13:50:15

Python電子表格編程語(yǔ)言

2022-07-11 12:14:56

Pandashtmljson

2021-05-16 07:08:18

ExcelWord技巧

2025-01-15 13:46:23

2012-01-17 14:09:54

JavaSwing

2020-11-06 08:28:44

Python

2016-01-15 10:01:12

PHPOCR實(shí)戰(zhàn)圖像

2025-06-20 08:52:58

點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

欧洲亚洲精品久久久久| 美女视频一区二区| 欧美va亚洲va在线观看蝴蝶网| 欧美 国产 精品| 伊人精品成人久久综合软件| 国产精品视频99| 伊人伊成久久人综合网小说| 亚洲色成人www永久在线观看| 国产视频一区不卡| 日韩欧美亚洲在线| 午夜影院日韩| 国产亚洲精品久久飘花| 最新欧美人z0oozo0| 国产成人精品一区二区三区| 久久夜色电影| 欧美精品久久久久a| 视频一区国产| 欧美高清视频免费观看| 天堂av一区| 午夜精品久久久久久99热软件| 国产va免费精品观看精品| 最新69国产成人精品视频免费| 久久毛片亚洲| 久久亚洲春色中文字幕| 6080成人| 欧美专区在线观看| 国产一区二区三区电影在线观看 | 国产视频精品在线| 久久男人av资源站| 亚洲精品日韩丝袜精品| 欧美aaa级| 国内精品久久久久久久| 欧美亚洲国产日韩| 国产美女搞久久| 韩国一区二区三区在线观看| 麻豆成人小视频| 久久91精品国产91久久小草| 久久久久99精品成人片| 欧美激情一区不卡| 亚洲精华国产精华| 欧美精选午夜久久久乱码6080| 成a人片在线观看| 亚洲欧美激情在线视频| 91久久精品无嫩草影院| 成人妇女淫片aaaa视频| 免费永久网站黄欧美| 成人在线免费高清视频| 国产精品国产三级国产| 国模精品一区二区| 欧美精品一区二区在线播放| 精品国产一区二区三区性色av| 97成人超碰免| 国产精品一页| 国产老熟妇精品观看| 亚洲国产裸拍裸体视频在线观看乱了| 91社区在线| 4虎在线播放1区| 一区二区三区中文在线| 日日夜夜精品| 国产精品一香蕉国产线看观看| 成人av国产| 免费黄色日本网站| 亚洲欧美国产一本综合首页| 亚洲精品久久久| 欧美a一区二区| 欧美国产激情视频| 亚洲欧洲另类国产综合| 国产区视频在线播放| 亚洲精品国产精品乱码不99按摩| 亚洲精品毛片| 亚洲free嫩bbb| 国产真实乱对白精彩久久| 欧美 日韩 国产 激情| 欧美伊人久久久久久久久影院 | 欧美一区二区三区精品电影| 夜夜精品视频| 91色国产在线| 日韩欧美亚洲一区二区| 97视频在线观看亚洲| 激情成人综合| 特级西西444| 欧美日韩激情美女| av午夜在线观看| 日本成人黄色免费看| 中文字幕在线观看不卡视频| 青檬在线电视剧在线观看| 亚洲电影免费观看高清| 91黄页在线观看| 欧美日韩一级黄| 中文字幕在线直播| 久久国内精品一国内精品| 亚洲精品一二三**| 黑人极品ⅴideos精品欧美棵| 这里只有精品在线播放| 黑人一区二区| 91xxxxx| 亚洲片av在线| 在线视频日韩| а√最新版地址在线天堂| 国产亚洲精品美女| 91久久视频| 麻豆传媒在线播放| 97视频国产在线| 91免费在线看| 日韩一级二级| 四虎影视永久免费在线观看一区二区三区| 亚洲亚洲人成综合网络| 久久成人福利| 丰满少妇被猛烈进入高清播放| 亚洲福利影片在线| 免播放器亚洲| 色综合久久影院| 成人动漫视频在线观看完整版 | av观看在线| 国产精品久久国产三级国电话系列| 国产精品女上位| 欧洲精品99毛片免费高清观看| 在线观看av的网址| 精品丝袜一区二区三区| 另类小说一区二区三区| 欧美伦理免费在线| 欧美大陆一区二区| 91精品在线免费观看| 在线视频观看日韩| a天堂中文在线| 精品国产一区二区三区免费 | 国产一区二区三区在线视频 | 中文字幕免费在线不卡| 欧美一区二区三区四区在线观看 | 国产亚洲精久久久久久| 成人性教育av免费网址| 国产精品久久成人免费观看| 亚洲国产精品va在线观看黑人| 亚洲自拍另类| av超碰免费在线| 中文字幕一区二区三区精彩视频| 欧美成人官网二区| 国内精品久久久久影院色| www.日韩| 国产熟女高潮视频| 97国产在线视频| 亚洲天堂福利av| av亚洲在线观看| 久色视频在线| 久久九九视频| 亚洲国产精品成人一区二区| 国产精品夜夜嗨| 国产精品3区| 高清hd写真福利在线播放| 国产精品视频在线播放| 91黄色小视频| 久久国产精品无码网站| 在线高清欧美| 婷婷综合影院| 久久99精品国产一区二区三区| 亚洲第一福利视频| 99re6这里只有精品视频在线观看| 91蜜桃臀久久一区二区| av一卡二卡| 国外成人免费视频| 日韩禁在线播放| 国产精品久久午夜| 99精品视频免费观看| 欧美free嫩15| 黄污在线观看| 亚洲制服中文| 8050国产精品久久久久久| 在线观看亚洲专区| 国产一区二区三区在线观看免费 | 国产精品69久久久久水密桃| 欧美一区一区| 男人av在线| 成人免费a级片| 国产精品入口免费视| 亚洲精品一区二区精华| 国产精品毛片无遮挡高清| 亚洲国产午夜| 人人九九精品视频| 性开放的欧美大片| 97在线播放视频| 99精品99久久久久久宅男| 中文字幕亚洲天堂| 日韩欧美亚洲成人| av高清不卡在线| 韩国在线一区| 韩国精品福利一区二区三区| 国产在线高清视频| 国产免费视频| 欧美 国产 精品| 91网站在线看| 久久精品国产91精品亚洲| 欧美性xxxxxxxx| 国产拍欧美日韩视频二区| 在线综合欧美| 亚洲专区视频| 日日av拍夜夜添久久免费| 大地资源中文在线观看免费版| 免费黄色特级片| 亚洲无玛一区| 国产精品v欧美精品v日韩精品 |