当前位置:   article > 正文

【上传csv格式的excel】_上传csv格式文件类型

上传csv格式文件类型

一、背景介绍

最近需要做一个导入,格式为.csv格式的,因为是系统间相互通信,所以限定导入格式为.csv,本篇文章做一个记录。

二、过程

因为功能开发比较着急,所以是以效率为前提:
主要代码如下:

/**
     * <b>将csv文件通过IO流解析,转化数组形式的集合<b>
     *
     * @param file 文件
     */
    public static List<String[]> csv(MultipartFile file) {
        List<String[]> csvList = new ArrayList<String[]>();
        try {
            InputStreamReader is = new InputStreamReader(file.getInputStream(), "UTF-8");
            CSVParser csvParser = new CSVParserBuilder().build();
            CSVReader reader = new CSVReaderBuilder(is).withCSVParser(csvParser).build();
            reader.skip(1);
            csvList = reader.readAll();
        } catch (IOException e) {
            e.printStackTrace();
        }
        return csvList;
    }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18

调用

 List<String[]> list = CsvUtil.csv(file);
  • 1

接收转换

 for (String[] product : list) {
 //转换最终的model
}
  • 1
  • 2
  • 3

后面为了便于查找问题,所以将用户上传的文件保存在aliyun oss 上面

   /**
     * 上传文件流
     *
     * @param inputStream
     * @return
     */
    public String uploadOssResource(String path, InputStream inputStream) {
        // 创建OSSClient实例。
        OSS ossClient = new OSSClientBuilder().build(ENDPOINT, aliKey, aliSecret);
        // 上传文件流。
        ossClient.putObject(BUCKET, path, inputStream);
        // 关闭OSSClient。
        ossClient.shutdown();
        return CDN_HOST + path;
    }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15

忘记了pom 文件引入:

        <dependency>
            <groupId>com.opencsv</groupId>
            <artifactId>opencsv</artifactId>
            <version>4.4</version>
        </dependency>
  • 1
  • 2
  • 3
  • 4
  • 5

三、总结

主要记录一下,感谢大家阅读。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/不正经/article/detail/599151
推荐阅读
相关标签
  

闽ICP备14008679号