首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >找不到Jave FIle

找不到Jave FIle
EN

Stack Overflow用户
提问于 2014-01-26 08:51:22
回答 3查看 1.6K关注 0票数 0

下面是使用Apache在Java中读取excel表的代码。尽管该文件存在,但为什么它会给我一个FileNotFound异常?

代码语言:javascript
复制
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中的路径有什么特殊之处?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2014-01-26 09:18:28

试试下面的代码:

代码语言:javascript
复制
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!");
        }
    }
}

我有三件事要指出:

  1. 首先,您没有添加一个try/catch block.My IDE,只是不让它编译!
  2. 如果您使用的是依赖于File.separator的文件路径,那么使用OS.They是更推荐的方法,而不是使用"\“或"/”,从而使您的代码更具可移植性。
  3. 如果使用f.exists()检查该文件是否存在,将让您知道是否存在作为参数传递给FileInputStream的文件。当然会有帮助的!!
票数 0
EN

Stack Overflow用户

发布于 2014-01-26 09:04:49

也许前两个'\‘只代表一个'\',所以您可以使用文件路径作为"C:\Personal\test.xlsx“

票数 0
EN

Stack Overflow用户

发布于 2014-01-26 09:11:02

建议:调用File.canRead()查看是否有打开文件的权限。

Java new File() says FileNotFoundException but file exists

有三种情况下可以抛出FileNotFoundException。

  1. 命名文件不存在。
  2. 命名文件实际上是一个目录。
  3. 由于某些原因,无法打开指定的文件进行读取。
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/21361504

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档