使用 OpenCSV 將 CSV 對映到 JavaBean


CSV 檔案基本上是純文字檔案,其資料儲存在以逗號分隔的列中。OpenCSV 是一個庫,用於解析這些 CSV 檔案,否則這些檔案很難處理。它是一個非常易於使用的庫,支援多種功能,例如帶有標題的 CSV 檔案的讀取和寫入。

本文將討論透過 OpenCSV 將 CSV 檔案對映到 JavaBean。此外,OpenCSV 是一個有助於此過程的工具。

將 CSV 對映到 JavaBean

OpenCSV 庫提供某些類和對映策略,用於將 CSV 檔案對映到 Java Bean。一個這樣的類是 CSVToBean,它用於將 CSV 檔案對映到 JavaBean。為了解析這些 CSV 檔案,CSVToBean 類需要一個需要定義並傳遞給 CSVToBean 類的對映策略。一種流行的對映策略是 HeaderColumnNameTranslateMappingStrategy,它將列 ID 對映到 Java bean 屬性。

語法

將 CSV 檔案對映到 Bean 是透過一系列步驟完成的。但是,使用列 ID 和 Bean 屬性之間對映建立 HashMap 的語法如下:

HashMap map = new HashMap();
map.put("column_id", "bean_property");

首先,我們建立了一個 HashMap,然後使用 HashMap 的 put() 函式將列 ID 與相應的 Java Bean 屬性對映。

演算法

  • 步驟 1 - 首先使用以下依賴項將 OpenCSV 新增到 Java 專案。

對於 Maven 專案,請將以下依賴項新增到 Java 專案:

<dependency>
   <groupId>com.opencsv</groupId>
   <artifactId>opencsv</artifactId>
   <version>4.1</version>
</dependency>

對於 Gradle 專案,您需要新增以下依賴項:

compile group: 'com.opencsv', name: 'opencsv', version: '4.1'
  • 步驟 2 - 現在,讓我們開始將 csv 檔案對映到 Java Bean 的基本步驟。

  • 步驟 3 - 建立一個 HashMap,其中包含列 ID 和 Bean 屬性之間的對映。

  • 步驟 4 - 新增 csv 檔案中所有與 Bean 屬性對應的列 ID。

  • 步驟 5 - 建立 HeaderColumnNameTranslateMappingStrategy 的物件。

  • 步驟 6 - 現在,將對映的 HashMap 傳遞給 setColumnMapping() 方法。

  • 步驟 7 - 呼叫 CSVToBean 和 CSVReader 類的物件。

  • 步驟 8 - 現在,我們將呼叫 CSVToBean 類的解析方法,並將 HeaderColumnNameTranslateMappingStrategy 和 CSVReader 物件傳遞給它。

  • 步驟 9 - 列印 Bean 物件的詳細資訊。

方法

現在,讓我們使用 OpenCSV 將 Employee.csv 檔案的內容對映到 JavaBean。Employee.csv 檔案包含員工姓名、部門和工資等資料。

Employee.csv 檔案的內容如下:

Employee_Name, Department, Salary
Naman, Human Resource, 45000
Nikita, Sales, 35000
Rocky, IT, 50000
Raman, Human Resource, 42000

現在,讓我們首先建立 Employee 類,然後建立將此 csv 檔案內容對映到 JavaBean 的 main 方法。

示例:Employee.java

public class Employee {
   private static final long serialVersionUID = 1L;
 
   public String emp_name, department, salary;
 
    public String getName() {
      return emp_name;
   }
 
   public void setName(String n) {
      emp_name  = n;
   }
 
   public String getSalary() {
      return salary;
   }
 
   public void setSalary(String s) {
      salary = s;
   }
 
   public String getDepartment() {
      return department;
   }
 
   public void setDepartment(String d) {
      d = department;
   }
   public String toString() {
      return "Employee [Name=" + emp_name + ", Department= " + department +",
         Salary = " + salary+ "]";
   }
}

以下是 CsvToBean.java 檔案的程式程式碼。

示例

import java.util.*;
import com.opencsv.CSVReader;
import com.opencsv.bean.CsvToBean;
import com.opencsv.bean.HeaderColumnNameTranslateMappingStrategy;

public class csvtobean {
   public static void main(String[] args) {
      Map<String, String> map = new HashMap<>();
      map.put("Employee_Name", "emp_name");
      map.put("Department", "department");
      map.put("Salary", "salary");
      HeaderColumnNameTranslateMappingStrategy<Employee> s =
         new HeaderColumnNameTranslateMappingStrategy<>();
      s.setType(Employee.class);
      s.setColumnMapping(map);
      CSVReader csvReader = null;
      try {
         csvReader = new CSVReader(new FileReader
         ("D:\CSVFiles\Employee.csv"));
      }
      catch (FileNotFoundException e) {
         e.printStackTrace();
      }
      CsvToBean csvToBean = new CsvToBean();
      List<Employee> l = csvToBean.parse(s, csvReader);
      for (Employee x : l) {
         System.out.println(x);
      }
   }
}

輸出

Employee [Name=Naman, Department=Human Resource, Salary=45000]
Employee [Name=Nikita, Department=Sales, Salary=35000]
Employee [Name=Rocky, Department=IT, Salary=50000]
Employee [Name=Raman, Department=Human Resource, Salary=42000]

如您在上面的程式程式碼中看到的,我們首先建立了一個 HashMap,用於將列 ID 與相應的 Bean 屬性對映。之後,我們為 Employee 類實現了 HeaderColumnNameTranslateMappingStrategy 策略,並將其傳遞給 CsvToBean 類的 parse 方法,以使用 OpenCSV 將 CSV 對映到 JavaBean。

結論

在本文中,我們學習瞭如何使用 OpenCSV 將 CSV 檔案對映到 JavaBean。討論的執行此操作的簡單技術是使用 CsvToBean 類和一個對映策略,該策略傳遞給 CsvToBean 類的物件。我們討論了使用 OpenCSV 將 csv 格式的員工資料解析到 JavaBean 的步驟和程式程式碼。

更新於:2023年7月28日

2K+ 次檢視

啟動您的 職業生涯

完成課程獲得認證

開始
廣告