我有一个代码可以从excel表中读取旧格式(97-2003) . 我对数据进行了一些更改,最终获得了2007格式的excel表 . 当我使用这个xlsx表而不是xls表时,我得到了这个:
jxl.read.biff.BiffException: Unable to recognize OLE stream
at jxl.read.biff.CompoundFile.<init>(CompoundFile.java:116)
at jxl.read.biff.File.<init>(File.java:127)
at jxl.Workbook.getWorkbook(Workbook.java:268)
at readexcel.ReadExcel.readContent(ReadExcel.java:50)
at readexcel.ReadExcel.init(ReadExcel.java:25)
at readexcel.ReadExcel.main(ReadExcel.java:183)
4 回答
xls格式(<Excel 2007)由OLE容器中的二进制BIFF数据组成 . xlsx格式(> = Excel 2007)由zip容器中的XML文件组成 .
Java Excel API仅处理第一种格式,因此它在不遇到OLE容器时会抛出异常 .
您需要将输入限制为仅限xls文件,或者找到另一种处理这两种格式的工具 .
“另存为”您的工作簿为“Excel 97-2003工作簿”(选项在Microsoft Excel 2007中提供)它将您的文件保存在OLE容器中 .
我只是遇到了同样的麻烦 . 项目基于Maven,以下指令的副作用是过滤XLS文件 .
干净的解决方法解决方案是定义子文件夹“config”并允许对此特定文件夹进行过滤,同时包括但不过滤其他子文件夹 .
我在Eclipse / Selenium中面临同样的问题,并尝试“另存为”97-2000(.xls),它解决了我的问题 .