我正在使用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构建路径中包含以下内容作为库;
我知道解决方案很简单,但我的想法是空白。我不是在使用maven。
答案 0 :(得分:4)
您需要添加XMLBeans依赖项。您可以在此处包含依赖项https://mvnrepository.com/artifact/org.apache.xmlbeans/xmlbeans/2.6.0
答案 1 :(得分:2)
正如异常消息告诉您的那样,您需要XMLBeans库。 Poi可能依赖它。
如果您使用的是依赖管理工具(如Gradle或Maven),则会自动包含它。