Apache POI ClassNotFoundException

时间:2016-09-02 15:43:37

标签: java eclipse apache-poi

我正在使用eclipse尝试从excel电子表格中获取工作表列表,但是当我去运行它时,Java会抛出异常。

这是代码;

File myFile = new File("excel.xlsx");
    Workbook wb = null;
    try {
        wb = WorkbookFactory.create(myFile);
    } catch (EncryptedDocumentException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    } catch (InvalidFormatException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    } catch (IOException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    }

    List<String> sheetNames = new ArrayList<String>();
    for (int i=0; i<wb.getNumberOfSheets(); i++) {
        sheetNames.add( wb.getSheetName(i) );
    }
    System.out.println(sheetNames);

这是日志;

Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/xmlbeans/XmlObject
    at org.apache.poi.ss.usermodel.WorkbookFactory.create(WorkbookFactory.java:293)
    at org.apache.poi.ss.usermodel.WorkbookFactory.create(WorkbookFactory.java:252)
    at org.apache.poi.ss.usermodel.WorkbookFactory.create(WorkbookFactory.java:231)
    at com.cogentautomation.view.View.main(View.java:19)
Caused by: java.lang.ClassNotFoundException: org.apache.xmlbeans.XmlObject
    at java.net.URLClassLoader.findClass(Unknown Source)
    at java.lang.ClassLoader.loadClass(Unknown Source)
    at sun.misc.Launcher$AppClassLoader.loadClass(Unknown Source)
    at java.lang.ClassLoader.loadClass(Unknown Source)
    ... 4 more

我在eclipse java构建路径中包含以下内容作为库;

  • commons-codec
  • commons-logging
  • junit
  • 的log4j
  • poi
  • POI-OOXML
  • POI暂存器

我知道解决方案很简单,但我的想法是空白。我不是在使用maven。

2 个答案:

答案 0 :(得分:4)

您需要添加XMLBeans依赖项。您可以在此处包含依赖项https://mvnrepository.com/artifact/org.apache.xmlbeans/xmlbeans/2.6.0

答案 1 :(得分:2)

正如异常消息告诉您的那样,您需要XMLBeans库。 Poi可能依赖它。

如果您使用的是依赖管理工具(如Gradle或Maven),则会自动包含它。