POI检查EXCEL版本(2003或2007)

本文介绍了一种使用Apache POI库来准确判断Excel文件版本(2003或2007)的方法。通过直接操作文件流而非依赖扩展名,确保了判断的准确性。文中提供了具体的Java代码示例,并指出了在实际应用中可能遇到的问题及其解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

鉴定Excel格式是否是2003或2007,如果你的做法是读取扩展名,那说明你还是一个菜鸟!因为后缀完全是我们可以随意更改,我们可以把xls改成xlsx,甚至是txt,exe,jpg的后缀改成xlsx。

不过不管扩展名如何改变,文件的字节是改不了的,所以一般鉴定文件的真正格式应该读取byte,一般前几个字节都决定了文件的格式,这个是改不了的

读取Excel格式用不着如此麻烦了,我们完全可以借助POI提供的功能去鉴定。POI的Workbook提供了两个实现类,HSSFWorkbook(处理2003)和XSSFWorkbook(处理2007)

代码如下:


public static boolean isExcel2003(InputStream is) {
try {
new HSSFWorkbook(is);
} catch (Exception e) {
return false;
}
return true;
}


public static boolean isExcel2007(InputStream is) {
try {
new XSSFWorkbook( is);
} catch (Exception e) {
return false;
}
return true;
}


调用


public static void main(String[] args) throws IOException {
String path ="C:\\Users\\QUINN\\Desktop\\template\\0.xlsx";
File file = new File(path);
InputStream is = new FileInputStream(file);
System.out.println(FileHelper.isExcel2003(is));
System.out.println(FileHelper.isExcel2007(is));
}


以上调用的方法是错误的,如果文件真的是2007,则会两个都返回false,原因后面再说,先看看正确的写法。

public static void main(String[] args) throws IOException {
String path ="C:\\Users\\QUINN\\Desktop\\template\\0.xlsx";
File file = new File(path);
System.out.println(FileHelper.isExcel2003(new FileInputStream(file)));
System.out.println(FileHelper.isExcel2007(new FileInputStream(file)));
}


后面这个才是正确的方式,前面的之所以不成功,那是因为在执行第一个方法isExcel2003的时候new了一个workbook,workbooknew完之后在POIFSFileSystem会有一个关闭流的操作,如图

[img]http://dl2.iteye.com/upload/attachment/0097/8182/b0be4f8b-b640-3f8f-a9f5-73adbd47589b.jpg[/img]

当执行到isExcel2007的时候还是那个InputStream对象,但是对象已经在isExcel2003的方法里被close了,所以在后面的方法里始终是报错的。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值