2011-03-16 108 views
3

我想通过Java阅读Microsoft Word文件。我已将Apache poi-3.8-beta1中的所有.jar文件包含到我的类路径中。然而,当我尝试运行此,我得到以下异常:使用Java阅读MS Word 2007

org.apache.poi.poifs.filesystem.OfficeXmlFileException: The supplied data appears to be in the Office 2007+ XML. You are calling the part of POI that deals with OLE2 Office Documents. You need to call a different part of POI to process this data (eg XSSF instead of HSSF) 
     at org.apache.poi.poifs.storage.HeaderBlock.<init>(HeaderBlock.java:131) 
     at org.apache.poi.poifs.storage.HeaderBlock.<init>(HeaderBlock.java:104) 
     at org.apache.poi.poifs.filesystem.POIFSFileSystem.<init>(POIFSFileSystem.java:138) 
     at readingmsword07.Main.main(Main.java:27) 

以下是我的代码:

import org.apache.poi.xwpf.extractor.XWPFWordExtractor; 
import java.io.File; 
import java.io.FileInputStream; 
import java.io.IOException; 
import java.io.InputStream; 
import java.io.*; 
import org.apache.poi.poifs.filesystem.POIFSFileSystem; 
import org.apache.poi.xwpf.usermodel.XWPFDocument; 


public class Main { 


    public static void main(String[] args) { 
     try { 
      FileInputStream fis = new FileInputStream("C:\\TrialDoc.docx"); 
      POIFSFileSystem fileSystem = new POIFSFileSystem(fis);    
      org.apache.poi.xwpf.extractor.XWPFWordExtractor oleTextExtractor = 
      new XWPFWordExtractor(new XWPFDocument(fis)); 
      System.out.print(oleTextExtractor.getText());    
     } catch (Exception e) { 
       e.printStackTrace(); 
     } 
    } 

} 

我现在用的是XWPFWordExtractor,因为我想读一个2007字的文件,但对于某些原因,我无法找出处理这个问题的正确POI。

任何帮助,非常感谢。提前致谢!

〜伍兹

回答

4

删除行,

POIFSFileSystem fileSystem = new POIFSFileSystem(fis); 
+0

这个工作现在...谢谢! – Wannabewoods 2011-03-17 02:08:00