情景:需要读取resources中的excel文件并且通过inputStream的方式去解析。

​ 问题:在本地测试的时候通过classPath:文件名.xlsx的方式可以正常获取,但是将代码打成jar包后报错提示找不到该文件,本地代码如下:

       File file = ResourceUtils.getFile("classpath:template.xlsx");
        InputStream inputStream = new FileInputStream(file);

报错原因:未打包之前的文件路径是在正常的target/classes中,打成jar包后,代码和文件放在同一层次下,导致获取不了文件。

​ 解决办法:很多种,最简单的,通过流的形式去获取文件,修改以上代码如下:

ClassPathResource resource = new ClassPathResource("\\template.xlsx");   
            InputStream inputStreams = resource.getInputStream();  

另外记录inputstream操作txt文件的方法,通过InputStreamReader更改为gbk语言后通过readLine去获取每一行的内容,从而进行操作处理。代码如下:

   InputStream inputStream = new FileInputStream("E:\\test.txt");
        InputStreamReader reader = new InputStreamReader(inputStream,"gbk");
        BufferedReader br = new BufferedReader(reader);
        String lineText = br.readLine();
    

可以写while循环去获取文件总行数。