下面是使用Apache在Java中读取excel表的代码。尽管该文件存在,但为什么它会给我一个FileNotFound异常?
import org.apache.poi.hssf.usermodel.HSSFSheet;
import java.io.FileInputStream;
import java.io.File;
public class ReadFromExcel {
public static void main(String[] args) {
FileInputStream file = new FileInputStream(new File("C:\\Personal\\test.xlsx"));
}
}我只是从windows资源管理器复制和粘贴了文件位置,这样我就知道文件确实存在。那为什么Java找不到呢?
与"File“类使用相同的路径,而不是"FileInputStream”,它工作得很好。类FileInputStream中的路径有什么特殊之处?
发布于 2014-01-26 09:18:28
试试下面的代码:
import org.apache.poi.hssf.usermodel.HSSFSheet;
import java.io.FileInputStream;
import java.io.File;
import java.io.FileNotFoundException;
public class ReadFromExcel {
public static void main(String[] args) throws FileNotFoundException {
File f=new File("C:"+File.separator+"Personal"+File.separator+"test.xlsx");
FileInputStream file=null;
if(f.exists()) {
file = new FileInputStream(f);
//rest of code
} else{
System.out.println("The file does not exist!Please enter correct filename!");
}
}
}我有三件事要指出:
File.separator的文件路径,那么使用OS.They是更推荐的方法,而不是使用"\“或"/”,从而使您的代码更具可移植性。f.exists()检查该文件是否存在,将让您知道是否存在作为参数传递给FileInputStream的文件。当然会有帮助的!!发布于 2014-01-26 09:04:49
也许前两个'\‘只代表一个'\',所以您可以使用文件路径作为"C:\Personal\test.xlsx“
发布于 2014-01-26 09:11:02
建议:调用File.canRead()查看是否有打开文件的权限。
Java new File() says FileNotFoundException but file exists
有三种情况下可以抛出FileNotFoundException。
https://stackoverflow.com/questions/21361504
复制相似问题