首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Apache POI -处理数据的无效部分

Apache POI -处理数据的无效部分
EN

Stack Overflow用户
提问于 2012-09-19 20:44:59
回答 2查看 20.3K关注 0票数 1

我使用Java Apache POI (hssf)访问Excel电子表格。我得到了以下错误:

代码语言:javascript
复制
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)

我错过了什么?

EN

回答 2

Stack Overflow用户

发布于 2012-09-19 21:07:43

若要open xlsx (Office Open XML)文件,应使用XSSFWorkbook而不是HSSFWorkbook,后者用于xls (Excel97-2003)文件。

如果您使用的是< 3.5版本的POI,则需要至少升级到3.5版,才能读取xlsx文件。下面是用于执行转换的guide,但本质上,您需要使用WorkbookFactory加载文件,它负责为您创建XSSFWorkbookHSSFWorkbook

代码语言:javascript
复制
Workbook workbook = WorkbookFactory.create(new File("file.xlsx"))
票数 9
EN

Stack Overflow用户

发布于 2015-01-22 18:20:30

打开excel工作表,确保它没有损坏。如果看到任何错误,请将文件另存为MS Excel 97-2003工作表。

还要确保您已将文件名指定为"**.xls“

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/12494982

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档