zoukankan      html  css  js  c++  java
  • JAVA读写CSV文件

     最近工作需要,需要读写CSV文件的数据,简单封装了一下

    依赖
    读写CSV文件只需引用`javacsv`这个依赖就可以了

    <dependency>
        <groupId>net.sourceforge.javacsv</groupId>
        <artifactId>javacsv</artifactId>
        <version>2.0</version>
    </dependency>

    读文件

      /**
         * Read from CSV
         *
         * @param separator 分隔符
         * @param filePath 文件路径
         * @return
         * */
        public static<T> List<T> readFromCSV(Character separator, String filePath) {
            CsvReader reader = null;
            List<T> result = new ArrayList<>();
            try {
                //如果生产文件乱码,windows下用gbk,linux用UTF-8
                reader = new CsvReader(filePath, separator, Charset.forName("GBK"));
    
                // 读取标题
                reader.readHeaders();
                // 逐条读取记录,直至读完
                while (reader.readRecord()) {
                    //读取第一例
                    reader.get(0);
                    //读取指定名字的列
                    reader.get("");
                }
            } catch (Exception e) {
                e.printStackTrace();
            } finally {
                if (null != reader) {
                    reader.close();
                }
            }
    
            return result;
        }

    因为甜大王比较喜欢将读取的一列封装为一个Object,同时为了工具更通用返回的结果类型是一个List<T>

    写文件

    /**
         * Write into CSV
         *
         * @param separator 分隔符
         * @param filePath 文件路径
         * @param strList 对应CSV中的一行记录
         * */
        public static void writeIntoCSV(Character separator, String filePath, List<List<String>> strList) {
            CsvWriter csvWriter = null;
            try {
                // 创建CSV写对象
                csvWriter = new CsvWriter(filePath, separator, Charset.forName("GBK"));
                // 写标题
                //String[] headers = {"FileName","FileSize","FileMD5"};
                //csvWriter.writeRecord(headers);
                for (List<String> list : strList) {
                        String[] writeLine = new String[list.size()];
                        list.toArray(writeLine);
                        csvWriter.writeRecord(writeLine);
                }
    
                csvWriter.close();
            } catch (IOException e) {
                e.printStackTrace();
            } finally {
                if (null != csvWriter) {
                    csvWriter.close();
                }
            }
        }


    附:完整代码

  • 相关阅读:
    Oracle 获取表结构信息
    EasyUI layout动态设置Split属性
    jquery easyui-datagrid 如何清空数据
    ORacle 复制表
    aspx调用webmethod
    RDLC添加链接
    Nginx 负载均衡 ip_hash , hash key(consistent) url_hash, least_conn
    Nginx 提升吞吐量利器 Keeplived
    Nginx Gzip 的正确使用
    Nginx 切割日志
  • 原文地址:https://www.cnblogs.com/Hdaydayup/p/11452696.html
Copyright © 2011-2022 走看看