Apache Commons 读写 CSV 文件

文章目录

一、Maven 引入

xml 复制代码
        <!-- https://mvnrepository.com/artifact/org.apache.commons/commons-csv -->
        <dependency>
            <groupId>org.apache.commons</groupId>
            <artifactId>commons-csv</artifactId>
            <version>1.8</version>
        </dependency>

二、代码实现

java 复制代码
import org.apache.commons.csv.CSVFormat;
import org.apache.commons.csv.CSVParser;
import org.apache.commons.csv.CSVRecord;

import java.io.BufferedReader;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.nio.file.Files;
import java.nio.file.Paths;
import java.util.zip.ZipEntry;
import java.util.zip.ZipInputStream;

public class ReadCsvNW {

    public static void main(String[] args) {
        try {
            InputStream inputStream = Files.newInputStream(Paths.get("D:\\Documents\\2024-06-16.zip"));
            ZipInputStream zis = new ZipInputStream(inputStream);
            ZipEntry entry;
            while ((entry = zis.getNextEntry()) != null) {
                if (!entry.isDirectory() && entry.getName().endsWith(".csv")) {

                    BufferedReader reader = new BufferedReader(new InputStreamReader(zis, "GBK"));
                    CSVParser csvParser = new CSVParser(reader, CSVFormat.EXCEL.withFirstRecordAsHeader());

                    if (entry.getName().equals("hehe.csv")) {
                        for (CSVRecord record : csvParser) {
                            // 方式一:通过下角标获取值
                            System.out.println("数据行:" + record.get(5));
                            // 方式一:通过表头列名获取值
                            System.out.println("数据行:" + record.get("name"));
                        }
                    }
                }
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

参考:使用Apache Commons CSV在Java中读写CSV

相关推荐
默默在路上35 分钟前
apache-hive-3.1.3 show databases;报错
hive·hadoop·apache
lkbhua莱克瓦241 小时前
Apache Maven全面解析
java·数据库·笔记·maven·apache
slongzhang_1 小时前
从0配置Apache+PHP+SSL开发环境
php·apache·ssl
roman_日积跬步-终至千里1 天前
【大数据】Apache Calcite架构:从 SQL 到执行计划的转换框架
大数据·架构·apache
xdpcxq10291 天前
Apache 详解 在 Ubuntu 24 中安装和配置 Apache
linux·ubuntu·apache
振华OPPO1 天前
开源高性能RPC框架:Apache Dubbo全览与实践指南
微服务·rpc·开源·apache·dubbo·总线
leikooo2 天前
ShardingSphere 下更新分片键导致的失败问题分析与解决
java·spring·apache
一个天蝎座 白勺 程序猿2 天前
Apache IoTDB(13):数据处理的双刃剑——FILL空值填充与LIMIT/SLIMIT分页查询实战指南
数据库·sql·ai·apache·时序数据库·iotdb
阿巴资源站2 天前
小程序原生授权手机号
小程序·apache
亲爱的非洲野猪2 天前
Apache Cassandra完全指南:架构、原理与生产实践深度解析
架构·apache·database·cassandra