POI导入2007EXCEL中遇到的文件描述符错误的问题

本文介绍了一种在使用Java Apache POI库读取Excel文件时遇到的Bad file descriptor异常情况及其解决办法。通过调整代码逻辑,采用直接指定文件路径而非使用输入流的方式成功解决了该问题。

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

在导入07excel的时候出现的一个异常,错误的文件描述符或者报bad file descriptor

java.io.IOException: Bad file descriptor
at java.io.FileInputStream.readBytes(Native Method) at java.io.FileInputStream.read(FileInputStream.java:177) at org.apache.poi.util.IOUtils.copy(IOUtils.java:85) at org.apache.poi.util.PackageHelper.open(PackageHelper.java:50) at org.apache.poi.xssf.usermodel.XSSFWorkbook.(XSSFWorkbook.java:176) at com.kedacom.shop.web.action.DbWatchAction.main(DbWatchAction.java:464)
[/java]
测试代码如下:

public static void main(String[] args) throws IOException {
		File f = new File("/root/Desktop/111.xlsx");
		InputStream is = new FileInputStream(f);
		if (is != null) {
			Workbook book = null;
    try {
    		book = (Workbook) new HSSFWorkbook(is);
    } catch (Exception ex) {
    		try {
				//book = new XSSFWorkbook(is);//这里提供的这个输入流的构造方法一直报错,改为path之后就ok了
				book = new XSSFWorkbook("/root/Desktop/111.xlsx");
			} catch (IOException e) {
				// TODO Auto-generated catch block
				e.printStackTrace();
			} catch (Exception e) {
				// TODO Auto-generated catch block
				e.printStackTrace();
			}finally{
				is.close();
			}
	       }
		}
}



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值