Java中获取某个目录下文件的方式
短信预约 -IT技能 免费直播动态提醒
目录
1.获取方式1
使用ClassPathResource获取路径下的文件。
一般来说,我们项目的配置文件及静态资源都会放置在resources目录下。有时我们在项目中使用到resources目录下的文件,这时我们可以使用Spring下的Resouce接口来读取。具体代码如下
Resource resource = new ClassPathResource(“static/Std_Resource_Train_Model.xls”);
// 因为Resouce是一个接口 所以我们可以使用它的实现类ClassPathResource来new一个对象。而构造方法的参数便是resources目录下的文件路径,注意这里是使用的相对路径(相对于resouces目录而言的)。
2.示例1
文件位置
service层
public void export() throws IOException {// String path = "classpath:templates/shelfimport.xlsx";// InputStream inputStream = new ClassPathResource("templates/shelfimport.xlsx").getInputStream();// String path1 = new ClassPathResource("templates/shelfimport.xlsx").getPath(); String filename = new ClassPathResource("templates/shelfimport.xlsx").getFilename(); InputStream inputStream = new ClassPathResource("templates/shelfimport.xlsx").getInputStream(); DynamicHeaderListener listener = new DynamicHeaderListener(); EasyExcel.read(inputStream, listener).sheet().headRowNumber(1).doReadSync(); List
3.获取方式2
使用当前类的getClass方法获取相应的文件。
4.示例2
String path = "template/shelfimport.xlsx"; InputStream resourceAsStream = this.getClass().getClassLoader().getResourceAsStream(path); DanyListener danyListener = new DanyListener(); EasyExcel.read(resourceAsStream, danyListener).sheet(0).headRowNumber(1).doRead(); List> dataList = danyListener.getDataList(); dataList.forEach((item) -> { item.forEach((K, V) -> { System.out.println(K); System.out.println(V); }); });
来源地址:https://blog.csdn.net/m0_72167535/article/details/128982729
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341