使用opencsv库可高效处理csv文件。读取时用csvreader类,注意设置编码、分隔符及跳过标题行;写入时用csvwriter类,自动处理转义且可控制引号;复杂结构可用csvtobean与beantocsv实现对象映射,提升代码可维护性。

处理CSV文件在Java开发中是很常见的需求,比如读取或导出数据。虽然Java标准库没有直接支持CSV的操作,但借助开源库OpenCSV可以非常方便地完成这些任务。下面是一些实际操作建议,帮助你快速上手。

读取CSV文件
如果你需要从一个CSV文件中读取数据,OpenCSV的CSVReader类是个不错的选择。使用它时要注意编码格式和分隔符设置。

举个例子:
假设你的CSV文件是以逗号分隔的,内容如下:
Name,Age,Email Tom,25,tom@example.com Jerry,30,jerry@example.com
你可以这样读取:
立即学习“Java免费学习笔记(深入)”;

try (CSVReader reader = new CSVReader(new FileReader("data.csv"))) {
List rows = reader.readAll();
for (String[] row : rows) {
System.out.println("姓名:" + row[0] + ",年龄:" + row[1]);
}
} 注意:
- 如果你的CSV文件有标题行,记得跳过或者用
withSkipLines(1)来忽略第一行。 - 分隔符不一定是逗号,也可能是制表符
\t或其他符号,可以通过构造CSVReader时传入参数指定。
写入CSV文件
写入CSV通常用于导出数据。OpenCSV提供了CSVWriter类,使用起来也很直观。
比如你想把一些用户信息写入到CSV文件中:
本文档是Websphere教程;WebSphere 是因特网的基础架构软件,也就是我们所说的中间件。它使企业能够开发、部署和集成新一代电子商务应用(如 B2B 的电子交易),并且支持从简单的 Web 发布到企业级事务处理的商务应用。希望本文档会给有需要的朋友带来帮助;感兴趣的朋友可以过来看看
try (CSVWriter writer = new CSVWriter(new FileWriter("output.csv"))) {
writer.writeNext(new String[]{"Name", "Age", "Email"});
writer.writeNext(new String[]{"Alice", "28", "alice@example.com"});
}常见注意事项:
- 默认写入的内容会自动加上引号,如果不需要可以用构造函数控制。
- 文件路径要确保有写权限,否则会抛异常。
- 如果数据中包含逗号或换行符,OpenCSV会自动帮你处理转义,不用担心破坏格式。
使用对象映射简化操作(CsvToBean & BeanToCsv)
当你的数据结构比较复杂时,可以直接将CSV与Java对象映射,避免手动处理数组索引。
例如有一个User类:
public class User {
private String name;
private int age;
private String email;
// getters and setters
}读取CSV并转换为对象列表:
try (Reader reader = new FileReader("users.csv")) {
CsvToBean csvToBean = new CsvToBeanBuilder(reader)
.withType(User.class)
.withIgnoreLeadingWhiteSpace(true)
.build();
List users = csvToBean.parse();
} 同样地,也可以反过来把对象列表写入CSV:
try (Writer writer = new FileWriter("output.csv")) {
StatefulBeanToCsv beanToCsv = new StatefulBeanToCsvBuilder(writer).build();
beanToCsv.write(users);
} 这种方式的好处是代码更清晰、可维护性高,尤其是字段较多的时候。
基本上就这些。OpenCSV功能很全,基本涵盖了读、写、映射等常见场景。刚开始可能觉得配置有点多,但熟悉之后你会发现它比手动处理CSV省事很多。









