0

我有两个问题。

  1. 如何使用Export.xlsx位于目录中的文件res/ 而不是这个

    try ( FileInputStream fileInputStream = new FileInputStream("C:\\Users\\student3\\"+sfilename+".xlsx"))

  2. 从文件中读取数据,该文件位于存档所在的同一目录中.jar

我试过什么?

第一。问。

String path = "res/"+sfilename+".xlsx";
System.out.println(getClass().getClassLoader().getResource(path).toString());
File file2 = new File(getClass().getClassLoader().getResource(path).toString());
try ( FileInputStream fileInputStream = new FileInputStream(file2))

file:/C:/Users/student/IdeaProjects/batch/out/production/batch/res/ExportBatch.xlsx
Work is finished!
java.io.FileNotFoundException: file:\C:\Users\student3\IdeaProjects\batch\out\production\batch\res\ExportBatch.xlsx (Синтаксическая ошибка в имени файла, имени папки или метке тома)
    at java.io.FileInputStream.open(Native Method)
    at java.io.FileInputStream.<init>(FileInputStream.java:138)
    at workhere.WriterXlsx.<init>(WriterXlsx.java:20)
    at workhere.Start.start(Start.java:62)
    at workhere.Start.main(Start.java:24)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:606)
    at com.intellij.rt.execution.application.AppMain.main(AppMain.java:120)

在此处输入图像描述

4

1 回答 1

2

你在路上。

该方法ClassLoader.getResource返回一个URL对象。您的System.out.println声明打印出此 URL。您可以看到 URL 协议“文件:”。

问题:File构造函数不需要 URL,而只需要文件的路径。这就是为什么FileInputStream找不到文件的原因。

解决方案:您不需要InputStream自己创建。只是URL.openStream用于那个。甚至更好:使用ClassLoader.getResourceAsStream.

例子:

String path = "res/" + sfilename + ".xlsx";
URL resURL = getClass().getClassLoader().getResource(path);
try (InputStream inputStream = resURL.openStream()) {
    ...
}

或者:

String path = "res/" + sfilename + ".xlsx";
try (InputStream inputStream = getClass().getClassLoader().getResourceAsStream(path)) {
    ...
}
于 2013-09-12T11:44:22.140 回答