Java获取resources资源文件夹下的文件和文件流(Maven项目)

本文介绍如何使用Java类加载器获取resources目录下的文件,包括通过输入流读取配置信息和通过URL生成File对象的方法。

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

在开发项目中经常获取resources下的文件(配置文件及其他各种各样的文件),本文通过java代码获取其文件及输入流;

主要用类加载器的两个重要方法

  • InputStream in = getClass().getClassLoader().getResourceAsStream("log4j.properties");// 获取文件的输入流
  • URL url = getClass().getClassLoader().getResource("log4j.properties");// 获取文件的URL

一、通过类加载器获取资源文件的文件流,输入流的用途很多,看你自己怎么用都可以,如用在Properties获取配置信息,或者用来读图片,文本等等......例子:读取resources下的log4j配置文件信息;

@Test
public void testStream() throws IOException, URISyntaxException {
	// 获取输入流
	InputStream in = getClass().getClassLoader().getResourceAsStream("log4j.properties");
	// 新建配置对象
	Properties p = new Properties();
	// 通过输入流加载
	p.load(in);
	// 读取key
	String log4j = p.getProperty("log4j.rootLogger");
	System.out.println(log4j);
}

运行后如下:

 

、通过类加载器获取资源文件的URL,URL的用法也是更加强大,可用用URL对象干很多,比如生成File对象,等可查看URL的API,例子:读取resources下的log4j生成File对象

@Test
public void testStream() throws IOException, URISyntaxException {
	// 获取URL
	URL url = getClass().getClassLoader().getResource("log4j.properties");
	// 通过url获取File的绝对路径
	File f = new File(url.getFile());
	System.out.println("文件的名子是:" + f.getName());
	System.out.println("文件的大小是:" + f.length());
}

运行后如下:

以上两个方法对于获取resources下的文件很有用途,多多利用,能幻化出多种用途,以后有关于获取路径及相对路径的内容继续更新(完)

### 访问 Resources 文件夹中的 Excel 文件 为了在 Java 项目中从 `resources` 目录下读取 Excel 文件,可以采用多种方式来加载并处理该文件。以下是具体的方法: #### 使用 ClassLoader 获取资源路径 通过 `ClassLoader` 可以方便地定位到位于 classpath 下的资源文件。对于 Excel 文件而言,通常会先将其置于项目的 `src/main/resources/` 路径之下。 ```java InputStream inputStream = PropertiesUtil.class.getClassLoader() .getResourceAsStream("excel/sample.xlsx"); if (inputStream == null) { throw new IllegalArgumentException( "File not found! Please check the file path."); } // 处理输入流... ``` 这段代码展示了如何利用 `getClassLoader()` 方法配合 `getResourceAsStream(String)` 来打开一个指向指定名称资源的输入流[^1]。 #### 利用 Apache POI 库解析 Excel 文档 一旦获得了 InputStream 对象之后,则可借助第三方库如 Apache POI 进行进一步的操作,比如读写单元格数据等。 ```xml <!-- Maven依赖 --> <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi-ooxml</artifactId> <version>5.2.3</version> </dependency> ``` 接着编写相应的业务逻辑代码片段如下所示: ```java Workbook workbook; try (var is = PropertiesUtil.class.getClassLoader() .getResourceAsStream("excel/sample.xlsx")) { if (is != null) { workbook = WorkbookFactory.create(is); Sheet sheet = workbook.getSheetAt(0); // 假设只有一张工作表 Iterator<Row> rowIterator = sheet.iterator(); while (rowIterator.hasNext()) { Row currentRow = rowIterator.next(); // 遍历每一列的数据项 Iterator<Cell> cellIterator = currentRow.cellIterator(); while(cellIterator.hasNext()){ Cell cell = cellIterator.next(); switch(cell.getCellType()){ case STRING: System.out.print(cell.getStringCellValue()); break; case NUMERIC: System.out.print(cell.getNumericCellValue()); break; default : ; } System.out.println(""); } } workbook.close(); } else { throw new FileNotFoundException("Excel file was not found!"); } } catch(IOException e){ e.printStackTrace(); } ``` 上述示例说明了怎样基于 Apache POI API 实现对 Excel 表单内信息提取的过程[^4]。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值