Java导入导出CSV文件,使用commons-csv

18 篇文章 0 订阅

废话不多说,直接上代码

但在上代码之前,首先需要准备一个csv文件,放入“D:/CSV”目录下,供导入解析数据使用

首先添加依赖

<!--导出CSV文件使用-->
<!-- https://mvnrepository.com/artifact/org.apache.commons/commons-csv -->
<dependency>
	<groupId>org.apache.commons</groupId>
	<artifactId>commons-csv</artifactId>
	<version>1.6</version>
</dependency>

Java代码

package com.example.demo.Util;

import org.apache.commons.csv.CSVFormat;
import org.apache.commons.csv.CSVParser;
import org.apache.commons.csv.CSVPrinter;
import org.apache.commons.csv.CSVRecord;

import java.io.*;
import java.util.Date;
import java.util.List;

/**
 * @Description TODO
 * @Author wangs
 * @Date 2019/12/5 17:01
 */
public class CSVUtil {

    /**
     * 导出
     */
    public static void exportCsv() throws IOException {
        File file =new File("D:/CSV");
        //判断路径是否存在,不存在则创建
        if(!file.exists()){
            file.mkdirs();
        }
        Appendable printWriter = new PrintWriter(file+"/wangs.csv","GBK");
        CSVPrinter csvPrinter = CSVFormat.EXCEL.withHeader("姓名", "性别", "年龄", "生日").print(printWriter);
        for (int i = 0; i < 10; i++) {
            csvPrinter.printRecord("lcf" + i, "M" + i, 18 + i, new Date());
        }
        csvPrinter.flush();
        csvPrinter.close();
    }

    public static void importCsv()throws IOException{
        InputStream inputStream =new FileInputStream("D:/CSV/导入.csv");//指定导入文件
        InputStreamReader inputStreamReader =new InputStreamReader(inputStream,"GBK");
        Reader reader = new BufferedReader(inputStreamReader);
        //指定csv的标题头
        CSVParser csvParser =CSVFormat.EXCEL.withHeader("name","sex","age","birthday").parse(reader);

        //将每一行记录存入list中
        List<CSVRecord> list = csvParser.getRecords();

        //变量循环list
       for(int i=0;i<list.size();i++){
           System.out.println(list.get(i).get("name")+":"+list.get(i).get("sex")+":"+list.get(i).get("age")+":"+list.get(i).get("birthday"));
       }
    }

    public static void main(String[] args) {
        try {
            CSVUtil.exportCsv();
            CSVUtil.importCsv();
        }catch (Exception e){

        }
    }
}

右键运行

会在“D:/CSV”下生成一个wangs.csv文件,文件内容如下:

本地“导入.csv”文件的内容如下:

解析后的内容如下:

成功!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值