springboot 获取目录文件

1、应用场景
Thread.currentThread().getContextClassLoader().getResourceAsStream 使用来导出Excel ,但是总是报空指针异常,发现是文件没有读取到!

2、读取文件的方式

方式一:
ClassPathResource classPathResource = new  ClassPathResource("template/xx.xlsx");

InputStream inputStream = classPathResource.getInputStream();

方式二:
InputStream inputStream = Thread.currentThread().getContextClassLoader().getResourceAsStream("template/xxx.xlsx");


方式三:
nputStream inputStream = this.getClass().getResourceAsStream("template/xxxx.xlsx");

pom文件中设置

<build>
        <resources>
            <resource>
                <directory>src/main/resources</directory>
                <includes>
                    <include>**/*.xlsx</include>
                    <include>**/*.properties</include>
                    <include>**/*.xml</include>
                    <include>**/*.yml</include>
                   
                </includes>
                <filtering>false</filtering>
            </resource>
            <resource>
                <directory>src/main/java</directory>
                <includes>
                    <include>**/*.xlsx</include>
                    <include>**/*.properties</include>
                    <include>**/*.xml</include>
                    <include>**/*.yml</include>
   
                </includes>
                <filtering>false</filtering>
            </resource>
        </resources>
    </build>

3、顺便解释一下

 1、include可以配置多个路径,但路径不要重复,也别包含
 2***/*意义不同,*指resource路径下,并不包含resource子文件夹下的文件
    **/*指resource路径及其子路径下所有文件

3.xls 是 Excel 1997-2003 版本的格式;.xlsx 是 Excel 2007 版本的格式
    .xls 是二进制的复合文档类型的结构;.xlsx 是用新的基于XML的压缩文件格式,使其占用空间更小,运算速度    也会快一点,xlsx 中最后一个 x 的意义就在于此。
    .xls 格式的文件所有 Office 程序都能打开,但.xlsx只有 Office 2007 或者更新的版本才能打开
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

行人已

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值