Rumah > Java > javaTutorial > teks badan

Memetakan CSV ke JavaBeans menggunakan OpenCSV

PHPz
Lepaskan: 2023-09-13 21:29:02
ke hadapan
950 orang telah melayarinya

使用 OpenCSV 将 CSV 映射到 JavaBean

Fail CSV pada asasnya ialah fail teks biasa yang menyimpan data dalam lajur yang dipisahkan koma. OpenCSV ialah perpustakaan untuk menghuraikan fail CSV ini, yang sebaliknya sukar untuk diproses. Ia adalah perpustakaan yang sangat mudah digunakan yang menyokong pelbagai fungsi seperti membaca dan menulis fail CSV dengan pengepala.

Dalam artikel ini, kita akan membincangkan proses pemetaan fail CSV ke JavaBeans melalui OpenCSV. Selain itu, OpenCSV ialah alat yang berguna dalam proses ini.

Peta CSV ke JavaBean

Pustaka OpenCSV menyediakan kelas dan strategi pemetaan untuk memetakan fail CSV ke Java Beans. Salah satu kelas ialah CSVToBean, yang digunakan untuk memetakan fail CSV ke JavaBeans. Untuk menghuraikan fail CSV ini, kelas CSVToBean memerlukan strategi pemetaan yang ditakrifkan dan dihantar kepada kelas CSVToBean. Salah satu strategi pemetaan yang popular ialah HeaderColumnNameTranslateMappingStrategy, yang memetakan ID lajur kepada sifat Java Bean.

tatabahasa

Fail CSV ke pemetaan Bean dilakukan melalui beberapa langkah. Walau bagaimanapun, sintaks untuk mencipta HashMap dengan pemetaan antara ID lajur dan sifat rasuk adalah seperti berikut -

HashMap map = new HashMap();
map.put("column_id", "bean_property");
Salin selepas log masuk

Pertama, kami mencipta peta hash dan kemudian menggunakan fungsi put() HashMap untuk memetakan id lajur dengan sifat kacang Java yang sepadan.

Algoritma

  • Langkah 1 - Mula-mula tambah OpenCSV pada projek Java anda menggunakan kebergantungan berikut.

Untuk projek Maven, tambahkan kebergantungan berikut pada projek java -

<dependency>
   <groupId>com.opencsv</groupId>
   <artifactId>opencsv</artifactId>
   <version>4.1</version>
</dependency>
Salin selepas log masuk

Untuk projek Gradle, anda perlu menambah kebergantungan berikut -

compile group: 'com.opencsv', name: 'opencsv', version: '4.1'
Salin selepas log masuk
  • Langkah 2 - Sekarang, mari mulakan langkah asas memetakan fail csv ke Java Bean.

  • Langkah 3 - Buat HashMap dengan pemetaan antara ID lajur dan sifat kacang.

  • Langkah 4 - Tambahkan semua id lajur fail csv yang sepadan dengan sifat kacang.

  • Langkah 5 − Cipta objek HeaderColumnNameTranslateMappingStrategy.

  • Langkah 6 - Sekarang, hantar peta cincang yang dipetakan kepada kaedah setColumnMapping().

  • Langkah 7 - Panggil objek kelas CSVToBean dan CSVReader.

  • Langkah 8 - Sekarang, kami akan memanggil kaedah parse kelas CSVToBean dan lulus HeaderColumnNameTranslateMappingStrategy dan objek CSVReader kepadanya.

  • Langkah 9 - Cetak butiran objek Bean.

kaedah

Sekarang, mari kita gunakan OpenCSV untuk memetakan kandungan fail Employee.csv ke JavaBeans. Fail Employee.csv mengandungi data seperti nama pekerja, jabatan dan gaji.

Kandungan fail Employee.csv adalah seperti berikut:

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

Sekarang, mari kita buat kelas Pekerja dahulu dan kemudian buat kaedah utama yang memetakan kandungan fail csv itu ke JavaBeans.

Contoh: 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+ "]";
   }
}
Salin selepas log masuk

Berikut ialah kod atur cara fail CsvToBean.java.

Contoh

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);
      }
   }
}
Salin selepas log masuk

Output

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]
Salin selepas log masuk

Seperti yang anda lihat dalam kod program di atas, kami mula-mula membuat peta cincang untuk memetakan ID lajur dengan sifat kacang yang sepadan. Kami kemudiannya melaksanakan strategi HeaderColumnNameTranslateMappingStrategy untuk kelas Pekerja dan menyerahkannya kepada kaedah parse kelas CsvToBean untuk memetakan CSV ke JavaBean menggunakan OpenCSV.

KESIMPULAN

Dalam artikel ini, kami melihat cara memetakan fail CSV ke JavaBeans menggunakan OpenCSV. Teknik mudah yang dibincangkan untuk melakukan ini ialah menggunakan kelas CsvToBean dan strategi pemetaan untuk objek yang dihantar ke kelas CsvToBean. Kami membincangkan langkah dan kod program untuk menghuraikan data pekerja dalam format csv ke dalam JavaBeans menggunakan OpenCSV.

Atas ialah kandungan terperinci Memetakan CSV ke JavaBeans menggunakan OpenCSV. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:tutorialspoint.com
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan
Tentang kita Penafian Sitemap
Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!