Rumah >Java >javaTutorial >Memetakan CSV ke JavaBeans menggunakan OpenCSV
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.
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.
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");
Pertama, kami mencipta peta hash dan kemudian menggunakan fungsi put() HashMap untuk memetakan id lajur dengan sifat kacang Java yang sepadan.
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>
Untuk projek Gradle, anda perlu menambah kebergantungan berikut -
compile group: 'com.opencsv', name: 'opencsv', version: '4.1'
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.
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
Sekarang, mari kita buat kelas Pekerja dahulu dan kemudian buat kaedah utama yang memetakan kandungan fail csv itu ke JavaBeans.
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+ "]"; } }
Berikut ialah kod atur cara fail 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]
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.
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!