0

我想读取由 Power Builder 应用程序生成的 Excel 文件(Office 版本 4)。这是代码:

File xls = new File("D:/excel.xls");
InputStream fis = new FileInputStream(xls);
HSSFWorkbook book = new HSSFWorkbook(fis);

当我尝试使用 POI 库 v3.17 读取 Excel 文件时,它会抛出此异常:

org.apache.poi.poifs.filesystem.NotOLE2FileException: Invalid header signature; read 0x0010000200040009, expected 0xE11AB1A1E011CFD0 - Your file appears not to be a valid OLE2 document
        at org.apache.poi.poifs.storage.HeaderBlock.<init>(HeaderBlock.java:144)

由于 Excel 文件是一个非常旧的版本,我尝试使用 POI v3.0-FINAL 读取它(我找不到旧版本)并抛出此异常:

java.io.IOException: Invalid header signature; read 4503608217567241, expected -2226271756974174256
    at org.apache.poi.poifs.storage.HeaderBlockReader.<init>(HeaderBlockReader.java:100)

我尝试使用 ODBC 读取 Excel 文件

String myDB = "jdbc: odbc: Driver = {Microsoft Excel Driver (*.xls)}; DBQ = d: /excel.xls;" + "DriverID = 22; READONLY = false";
Connection with = DriverManager.getConnection (myDB, "", "");

但它抛出异常:

java.sql.SQLException: [Microsoft] [ODBC Driver Manager] The name of
the data source is not found and no default drivers were specified

我还尝试使用 jxl 库读取 Excel 文件

Workbook workbook = Workbook.getWorkbook (new File ("d:/excel.xls"));

但是抛出这个异常:

jxl.read.biff.BiffException: Unable to recognize OLE stream

任何人都可以帮助我使用任何 Java 库阅读 Excel 文件版本 4 (1994) 吗?

我正在使用 JDK 1.7

4

1 回答 1

0

Apache POI HSSF 格式适用于 .xls 文件。您尝试读取的文件是 .xml。尝试使用 XSSF 类。

XSSFWorkbook book = new XSSFWorkbook(fis);

于 2018-05-25T23:49:05.593 回答