我使用Java Apache POI (hssf)访问Excel电子表格。我得到了以下错误:
java.lang.RuntimeException: 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.testng.internal.MethodInvocationHelper.invokeDataProvider(MethodInvocationHelper.java:143)
at org.testng.internal.Parameters.handleParameters(Parameters.java:426)我错过了什么?
发布于 2012-09-19 21:07:43
若要open xlsx (Office Open XML)文件,应使用XSSFWorkbook而不是HSSFWorkbook,后者用于xls (Excel97-2003)文件。
如果您使用的是< 3.5版本的POI,则需要至少升级到3.5版,才能读取xlsx文件。下面是用于执行转换的guide,但本质上,您需要使用WorkbookFactory加载文件,它负责为您创建XSSFWorkbook或HSSFWorkbook:
Workbook workbook = WorkbookFactory.create(new File("file.xlsx"))发布于 2015-01-22 18:20:30
打开excel工作表,确保它没有损坏。如果看到任何错误,请将文件另存为MS Excel 97-2003工作表。
还要确保您已将文件名指定为"**.xls“
https://stackoverflow.com/questions/12494982
复制相似问题