Java读取CSV文件

Maven依赖

	<dependency>
       <groupId>net.sourceforge.javacsv</groupId>
       <artifactId>javacsv</artifactId>
       <version>2.0</version>
    </dependency>
@Slf4j
public class CsvUtils {

    /**
     * 解析CSV文件
     */
    public static ArrayList<String[]> csv(InputStream in) {
        return csv(in,"GBK");
    }

    /**
     * 解析CSV文件
     */
    public static ArrayList<String[]> csv(InputStream in,String charset) {
        ArrayList<String[]> csvList = new ArrayList<String[]>();
        if (null != in) {
            //CsvReader reader = new CsvReader(in, ',', Charset.forName("GBK"));
            CsvReader reader = new CsvReader(in, ',', Charset.forName(charset));
            try {
                //遍历每一行,若有#注释部分,则不处理,若没有,则加入csvList
                while (reader.readRecord()) {
                    if (!reader.getValues()[0].contains("#"))// 清除注释部分
                    {
                        //获取的为每一行的信息,以数reader.getValues()组的形式
                        csvList.add(reader.getValues());
                    }
                }
            } catch (IOException e) {
                log.error("CSV文件解析异常:",e);
            }finally {
               if (reader != null){
                   reader.close();
               }
                try {
                    if (in != null){
                        in.close();
                    }
                } catch (IOException e) {
                    log.error("CSV文件解析IO关闭异常:",e);
                }
            }
        }
        return csvList;
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值