如何用Java處理CSV文件?OpenCSV教程

使用opencsv庫可高效處理csv文件。讀取時用csvreader類,注意設置編碼、分隔符及跳過標題行;寫入時用csvwriter類,自動處理轉義且可控制引號;復雜結構可用csvtobean與beantocsv實現對象映射,提升代碼可維護性。

如何用Java處理CSV文件?OpenCSV教程

處理csv文件Java開發中是很常見的需求,比如讀取或導出數據。雖然Java標準庫沒有直接支持CSV的操作,但借助開源庫OpenCSV可以非常方便地完成這些任務。下面是一些實際操作建議,幫助你快速上手。

如何用Java處理CSV文件?OpenCSV教程


讀取CSV文件

如果你需要從一個CSV文件中讀取數據,OpenCSV的CSVReader類是個不錯的選擇。使用它時要注意編碼格式和分隔符設置。

如何用Java處理CSV文件?OpenCSV教程

舉個例子:
假設你的CSV文件是以逗號分隔的,內容如下:

Name,Age,Email Tom,25,tom@example.com Jerry,30,jerry@example.com

你可以這樣讀?。?/p>

立即學習Java免費學習筆記(深入)”;

如何用Java處理CSV文件?OpenCSV教程

try (CSVReader reader = new CSVReader(new FileReader("data.csv"))) {     List<String[]> rows = reader.readAll();     for (String[] row : rows) {         System.out.println("姓名:" + row[0] + ",年齡:" + row[1]);     } }

注意:

  • 如果你的CSV文件有標題行,記得跳過或者用withSkipLines(1)來忽略第一行。
  • 分隔符不一定是逗號,也可能是制表符t或其他符號,可以通過構造CSVReader時傳入參數指定。

寫入CSV文件

寫入CSV通常用于導出數據。OpenCSV提供了CSVWriter類,使用起來也很直觀。

比如你想把一些用戶信息寫入到CSV文件中:

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<User> csvToBean = new CsvToBeanBuilder<User>(reader)         .withType(User.class)         .withIgnoreLeadingWhiteSpace(true)         .build();      List<User> users = csvToBean.parse(); }

同樣地,也可以反過來把對象列表寫入CSV:

try (Writer writer = new FileWriter("output.csv")) {     StatefulBeanToCsv<User> beanToCsv = new StatefulBeanToCsvBuilder<User>(writer).build();     beanToCsv.write(users); }

這種方式的好處是代碼更清晰、可維護性高,尤其是字段較多的時候。


基本上就這些。OpenCSV功能很全,基本涵蓋了讀、寫、映射等常見場景。剛開始可能覺得配置有點多,但熟悉之后你會發現它比手動處理CSV省事很多。

? 版權聲明
THE END
喜歡就支持一下吧
點贊10 分享