首頁  >  文章  >  Java  >  使用 OpenCSV 將 CSV 對應到 JavaBean

使用 OpenCSV 將 CSV 對應到 JavaBean

PHPz
PHPz轉載
2023-09-13 21:29:021026瀏覽

使用 OpenCSV 将 CSV 映射到 JavaBean

CSV檔案基本上是以逗號分隔的欄位儲存資料的純文字檔案。 OpenCSV是解析這些CSV檔案的函式庫,否則很難處理。它是一個非常易於使用的庫,支援讀寫帶有標題的CSV檔案等多個功能。

在本文中,我們將討論透過OpenCSV將CSV檔案對應到JavaBeans的過程。此外,OpenCSV是一個在這個過程中有幫助的工具。

將 CSV 對應到 JavaBean

OpenCSV庫提供了一些類別和映射策略,用於將CSV檔案對應到Java Beans。其中一個類別是CSVToBean,用於將CSV檔案對應到JavaBeans。要解析這些CSV文件,CSVToBean類別需要定義並傳遞給CSVToBean類別的映射策略。其中一個流行的映射策略是HeaderColumnNameTranslateMappingStrategy,它將列ID對應到Java Bean屬性。

文法

CSV 檔案到 Bean 的對應是透過一系列步驟完成的。然而,建立具有列 ID 和梁屬性之間的對應的 HashMap 的語法如下 -

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

首先,我們建立了一個 hashmap,然後使用 HashMap 的 put() 函數將列 id 與對應的 Java bean 屬性進行對應。

演算法

  • 第一步 - 首先使用以下相依性將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 - 使用列 ID 和 bean 屬性之間的對應建立一個 HashMap。

  • 步驟 4 - 新增與 bean 屬性對應的 csv 檔案的所有欄位 id。

  • 步驟 5 − 建立 HeaderColumnNameTranslateMappingStrategy 物件。

  • 第 6 步 - 現在,將映射的雜湊圖傳遞給 setColumnMapping() 方法。

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

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

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

方法

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

Employee.csv檔案的內容如下:

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

現在,讓我們先建立 Employee 類,然後建立將該 csv 檔案的內容對應到 JavaBeans 的 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]

如您在上述程式碼中所見,我們首先建立了一個哈希映射,將列ID與對應的bean屬性進行映射。然後,我們為Employee類別實作了HeaderColumnNameTranslateMappingStrategy策略,並將其傳遞給CsvToBean類別的parse方法,以使用OpenCSV將CSV對應到JavaBean。

結論

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

以上是使用 OpenCSV 將 CSV 對應到 JavaBean的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:tutorialspoint.com。如有侵權,請聯絡admin@php.cn刪除