在上一篇文章中 ,lucene只能全文检索word2003,无法检索2007,并且只能加载部分内容,无法加载全文内容。为解决此问题,找到了如下方法

POI 读取word (word 2003 和 word 2007)

最近在给客户做系统的时候,用户提出需求,要能够导入 word 文件,现在 microsoft word 有好几个版本 97、2003、2007的,这三个版本存储数据的格式上都有相当大的差别,而现在 97 基本上已经退出市场,几乎没有人用这个版本了, 所以在我们的系统中只考虑 2003 版本和 2007 版本的,因为我们只要求能够读取 word 中的文字内容即可,其中的文字样式、图片等信息可以忽略,也不用直接操作 word 文件, 所以我们选择 用 apache 的 POI 进行读取。

读取 2003 版本(.doc)的word文件相对来说比较简单,只需要 poi-3.5-beta6-20090622.jar 和 poi-scratchpad-3.5-beta6-20090622.jar 两个 jar 包即可, 而 2007 版本(.docx)就麻烦多,我说的这个麻烦不是我们写代码的时候麻烦,是要导入的 jar 包比较的多,有如下 7 个之多:
 1. openxml4j-bin-beta.jar
 2. poi-3.5-beta6-20090622.jar
 3. poi-ooxml-3.5-beta6-20090622.jar
 4 .dom4j-1.6.1.jar
 5. geronimo-stax-api_1.0_spec-1.0.jar
 6. ooxml-schemas-1.0.jar
 7. xmlbeans-2.3.0.jar
其中 4-7 是 poi-ooxml-3.5-beta6-20090622.jar 所依赖的 jar 包(在 poi-bin-3.5-beta6-20090622.tar.gz 中的 ooxml-lib 目录下可以找到)。

编写代码之前我们得先下载所需要的 jar 包, 我们只需下载 poi-bin-3.5-beta6-20090622.tar.gz 和 openxml4j-bin-beta.jar 即可,因为所需要的其他 jar 包都能在 poi-bin-3.5-beta6-20090622.tar.gz 中找到, 下面是下载地址:
poi-bin-3.5-beta6-20090622.tar.gz:http://apache.etoak.com/poi/dev/bin/poi-bin-3.5-beta6-20090622.tar.gz
openxml4j-bin-beta.jar:http://mirror.optus.net/sourceforge/o/op/openxml4j/openxml4j-bin-beta.jar
 
    下方是读取 word 文件的 Java 代码,值得注意的是: POI 在读取 word 文件的时候不会读取 word 文件中的图片信息, 还有就是对于 2007 版的 word(.docx), 如果 word 文件中有表格,所有表格中的数据都会在读取出来的字符串的最后。

  1. import java.io.File;
  2. import java.io.FileInputStream;
  3. import java.io.InputStream;
  4.  
  5. import org.apache.poi.POIXMLDocument;
  6. import org.apache.poi.POIXMLTextExtractor;
  7. import org.apache.poi.hwpf.extractor.WordExtractor;
  8. import org.apache.poi.openxml4j.opc.OPCPackage;
  9. import org.apache.poi.xwpf.extractor.XWPFWordExtractor;
  10.  
  11. /**
  12. * POI 读取 word 2003 和 word 2007 中文字内容的测试类<br />
  13. * @createDate 2009-07-25
  14. * @author Carl He
  15. */
  16. public class Test {
  17. public static void main(String[] args) {
  18. try {
  19. //word 2003: 图片不会被读取
  20. InputStream is = new FileInputStream(new File("c://files//2003.doc"));
  21. WordExtractor ex = new WordExtractor(is);
  22. String text2003 = ex.getText();
  23. System.out.println(text2003);
  24.  
  25. //word 2007 图片不会被读取, 表格中的数据会被放在字符串的最后
  26. OPCPackage opcPackage = POIXMLDocument.openPackage("c://files//2007.docx");
  27. POIXMLTextExtractor extractor = new XWPFWordExtractor(opcPackage);
  28. String text2007 = extractor.getText();
  29. System.out.println(text2007);
  30.  
  31. } catch (Exception e) {
  32. e.printStackTrace();
  33. }
  34. }
  35. }

 找到方法后,我们对上一篇文章indexer.java的源码进行更改,新增函数getDocument2007(),getDocument2003()

本版本lucene是4.9

  1. public static Document getDocument2007(File file) throws Exception {
  2.  
  3. String docPath = file.getAbsolutePath();
  4. String title = file.getName();
  5.  
  6. // 鍒涘缓Document
  7. Document document = new Document();
  8. OPCPackage opcPackage = POIXMLDocument.openPackage(docPath);
  9. POIXMLTextExtractor extractor = new XWPFWordExtractor(opcPackage);
  10. String cont = extractor.getText();
  11. document.add(new StringField("filename", title, Field.Store.YES));//TOKENIZED
  12. //document.add(new Field("contents", contents));
  13. document.add(new TextField("contents", cont,Field.Store.YES));
  14. document.add(new TextField("path", docPath, Field.Store.YES));
  15. document.add(new StringField("indexDate",DateTools.dateToString(new Date(), DateTools.Resolution.DAY),
  16. Field.Store.YES));
  17. return document;
  18. }
  19. public static Document getDocument2003(File file) throws Exception {
  20. String docPath = file.getAbsolutePath();
  21. String title = file.getName();
  22.  
  23. // 鍒涘缓Document
  24. Document document = new Document();
  25. InputStream is = new FileInputStream(new File(docPath));
  26. WordExtractor ex = new WordExtractor(is);//is鏄疻ORD鏂囦欢鐨処nputStream
  27. String cont = ex.getText();
  28.  
  29. document.add(new StringField("filename", title, Field.Store.YES));//TOKENIZED
  30. document.add(new TextField("contents", cont,Field.Store.YES));
  31. document.add(new TextField("path", docPath, Field.Store.YES));
  32. document.add(new StringField("indexDate",DateTools.dateToString(new Date(), DateTools.Resolution.DAY),
  33. Field.Store.YES));
  34. return document;
  35. }

  

 同时修改for循环中的读取文件

if(files[i].getName().endsWith(".doc")){
doc = getDocument2003(files[i]);
}else if(files[i].getName().endsWith(".docx")){
doc = getDocument2007(files[i]);
}

lucene解决全文检索word2003,word2007的办法的更多相关文章

  1. 解决GOOGLE不能用的办法

    解决GOOGLE不能用的办法 首先平时用用百度还是足够了,但是说实话,百度在进行一些尝试搜索时真的没GOOGLE好用,经常找到一大堆广告,却不是自己想要的,比如搜索里面的双引号.and.site.fi ...

  2. Jenkins解决无法获取插件的办法(升级站点目录)

    Jenkins解决无法获取插件的办法 可能是由于Jenkins的更新网站被QIANG,因此,请替换插件的服务器地址: http://mirror.xmission.com/jenkins/update ...

  3. JAVAEE——Lucene基础:什么是全文检索、Lucene实现全文检索的流程、配置开发环境、索引库创建与管理

    1. 学习计划 第一天:Lucene的基础知识 1.案例分析:什么是全文检索,如何实现全文检索 2.Lucene实现全文检索的流程 a) 创建索引 b) 查询索引 3.配置开发环境 4.创建索引库 5 ...

  4. 彻底解决mysql中文乱码的办法 ???

      MySQL会出现中文乱码的原因不外乎下列几点:1.server本身设定问题,例如还停留在latin12.table的语系设定问题(包含character与collation)3.客户端程式(例如p ...

  5. 彻底解决mysql中文乱码的办法,修改mysql解压缩版(免安装版或zip版)字符编码

    MySQL会出现中文乱码的原因不外乎下列几点:1.server本身设定问题,例如server字符编码还停留在latin12.table的语系设定问题(包含character与collation)3.客 ...

  6. eclipse 项目修改和更新项目,回退版本,解决分支的冲突的办法

    一个关于git的图 1.我在github建立了3个分支. 2.把其中一个分支拉到本地. 项目修改提交到远程库 3.修改完代码以后commit项目,点击项目右击->team->commit ...

  7. mysql 线程等待时间,解决sleep进程过多的办法

    如果你没有修改过MySQL的配置,缺省情况下,wait_timeout的初始值是28800.   wait_timeout 过大有弊端,其体现就是MySQL里大量的SLEEP进程无法及时释放,拖累系统 ...

  8. lucene教程--全文检索技术

    1    Lucene 示例代码        https://blog.csdn.net/qzqanzc/article/details/80916430 2   Lucene 实例教程(一)初识L ...

  9. 解决vim没有颜色的办法

    首先打开vim,输入命令 scriptnames看看vim加载了哪些脚本. :scriptnames 输出入下 : /home/users/xxx/.vimrc : /home/users/xxx/t ...

随机推荐

  1. linux jmail乱码

    在Windows 里面,标题和内容都正常, 在linux里面,--- 1.字符串 more /etc/sysconfig/i18n   export LANG=en_US.UTF-8 ====默认是e ...

  2. my.cnf 中字符集设置

    我们的一些业务系统最近出现了一种情况,尤其是新版的ios 设备,在发布消息时,使用了表情符号时,   对gbk 字符集的数据库,写入数据库的数据,在回显时,变成 ‘口口’ 无法回显,   对utf8 ...

  3. count(1) count(*)

    mysql from t; +---+ | +---+ | | | | +---+ rows in set (0.00 sec) mysql) from t; +----------+ ) | +-- ...

  4. cocos2d-x 2.1.4学习笔记01:windows平台搭建cocos2d-x开发环境

    cocos2d-x的大致开发流程是,首先使用win32版进行代码编写并完成游戏,然后将代码迁移到对应的开发环境上进行交叉编译完成游戏打包,如iphone上是mac+xcode,android是ecli ...

  5. Linux Ubuntu上架设FTP

    操作系统:ubuntu (GNU/Linux) 为了在机子上架设ftp服务器,我们需要安装ftp服务器软件.Linux下具有代表性的ftp服务器软件有Wu-FTP,ProFTP和Vsftp.Wu-FT ...

  6. 20 个强大的 Sublime Text 插件

    20. FTPSync 默认情况下SublimeText不具备FTP的功能,如果你正在寻找能在您的SublimeText应用程序中使用的免费和易用的FTP工具,你可以考虑FTPSync.这是一个非常简 ...

  7. iOS开发UI篇-实现tableView的层级显示

     进来要实现一个tableView 的cell层级显示,网上找的思路都各不相同.下面说一下我的实现思路.  根据根标题存储cell的展开状态,添加到字典中. 话不多说,直接上代码. #define S ...

  8. javascript中的内置对象

    2015.12.1 javascript中的内置对象 复习: 1.js中的内置函数 alert prompt write parseInt parseFloat eval isNaN document ...

  9. c语言,strcpy

    #include <stdio.h> #include <string.h> int main() {  char string[10];  char *str="a ...

  10. Flume简介与使用(一)——Flume安装与配置

    Flume简介与使用(一)——Flume安装与配置 Flume简介 Flume是一个分布式的.可靠的.实用的服务——从不同的数据源高效的采集.整合.移动海量数据. 分布式:可以多台机器同时运行采集数据 ...