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.
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");
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>
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.
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
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+ "]";
}
}
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);
}
}
}
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]
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!
Alat AI Hot
Undress AI Tool
Gambar buka pakaian secara percuma
Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik
AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.
Clothoff.io
Penyingkiran pakaian AI
Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!
Artikel Panas
Alat panas
Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma
SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan
Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa
Dreamweaver CS6
Alat pembangunan web visual
SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)
Topik panas
Mengapa kita memerlukan kelas pembalut?
Jun 28, 2025 am 01:01 AM
Java menggunakan kelas pembalut kerana jenis data asas tidak dapat mengambil bahagian secara langsung dalam operasi berorientasikan objek, dan bentuk objek sering diperlukan dalam keperluan sebenar; 1. Kelas koleksi hanya boleh menyimpan objek, seperti senarai menggunakan tinju automatik untuk menyimpan nilai berangka; 2. Generik tidak menyokong jenis asas, dan kelas pembungkusan mesti digunakan sebagai parameter jenis; 3. Kelas pembungkusan boleh mewakili nilai null untuk membezakan data yang tidak tersendiri atau hilang; 4. Kelas pembungkusan menyediakan kaedah praktikal seperti penukaran rentetan untuk memudahkan parsing dan pemprosesan data, jadi dalam senario di mana ciri -ciri ini diperlukan, kelas pembungkusan sangat diperlukan.
Perbezaan antara hashmap dan hashtable?
Jun 24, 2025 pm 09:41 PM
Perbezaan antara hashmap dan hashtable terutamanya dicerminkan dalam keselamatan benang, sokongan nilai null dan prestasi. 1. Dari segi keselamatan benang, hashtable adalah benang selamat, dan kaedahnya kebanyakannya kaedah segerak, sementara hashmap tidak melakukan pemprosesan penyegerakan, yang bukan benang-selamat; 2. Dari segi sokongan nilai null, hashmap membolehkan satu kunci null dan nilai null berbilang, manakala hashtable tidak membenarkan kekunci atau nilai null, jika tidak, nullPointerException akan dibuang; 3. Dari segi prestasi, hashmap lebih cekap kerana tidak ada mekanisme penyegerakan, dan Hashtable mempunyai prestasi penguncian yang rendah untuk setiap operasi. Adalah disyorkan untuk menggunakan ConcurrentHashMap sebaliknya.
Bagaimanakah pengkompil JIT mengoptimumkan kod?
Jun 24, 2025 pm 10:45 PM
Penyusun JIT mengoptimumkan kod melalui empat kaedah: kaedah dalam talian, pengesanan tempat panas dan penyusunan, spekulasi jenis dan devirtualisasi, dan penghapusan operasi yang berlebihan. 1. Kaedah sebaris mengurangkan panggilan overhead dan memasukkan kaedah kecil yang sering dipanggil terus ke dalam panggilan; 2. Pengesanan tempat panas dan pelaksanaan kod frekuensi tinggi dan mengoptimumkannya untuk menjimatkan sumber; 3. Jenis spekulasi mengumpul maklumat jenis runtime untuk mencapai panggilan devirtualisasi, meningkatkan kecekapan; 4. Operasi berlebihan menghapuskan pengiraan dan pemeriksaan yang tidak berguna berdasarkan penghapusan data operasi, meningkatkan prestasi.
Apakah kaedah statik dalam antara muka?
Jun 24, 2025 pm 10:57 PM
Staticmethodsininterfaceswereintroducedinjava8toallowutilityfunctionswithintheintheinterfaceitself.beforjava8, SuchfunctionsRequiredseparateHelpereHelperes, LeadingTodisorgaganizedCode.Now, staticmethodethreeKeybeeMeKeBeReSes, staticmethodeDethreeKeybeeMeKeBeReSes, staticmethodethreeKeybeeMeKeKeBeReSes, staticmethodeDethreeKeybeeMeKeKeBeReKeNey
Apakah blok inisialisasi contoh?
Jun 25, 2025 pm 12:21 PM
Blok permulaan contoh digunakan dalam Java untuk menjalankan logik inisialisasi apabila membuat objek, yang dilaksanakan sebelum pembina. Ia sesuai untuk senario di mana beberapa pembina berkongsi kod inisialisasi, permulaan medan kompleks, atau senario permulaan kelas tanpa nama. Tidak seperti blok inisialisasi statik, ia dilaksanakan setiap kali ia ditegaskan, manakala blok permulaan statik hanya dijalankan sekali apabila kelas dimuatkan.
Apakah kata kunci `akhir` untuk pembolehubah?
Jun 24, 2025 pm 07:29 PM
Injava, thefinalkeywordpreventsavariable'svaluefrombeingchangedafterassignment, butitsbehaviordiffersforprimitivesandobjectreferences.forprimitiveVariables, finalmakesthevalueconstant, asinfinalintmax_speed = 100;
Apakah jenis pemutus?
Jun 24, 2025 pm 11:09 PM
Terdapat dua jenis penukaran: tersirat dan eksplisit. 1. Penukaran tersirat berlaku secara automatik, seperti menukar int untuk berganda; 2. Penukaran eksplisit memerlukan operasi manual, seperti menggunakan (int) mydouble. Kes di mana penukaran jenis diperlukan termasuk memproses input pengguna, operasi matematik, atau lulus pelbagai jenis nilai antara fungsi. Isu-isu yang perlu diperhatikan adalah: Mengubah nombor terapung ke dalam bilangan bulat akan memotong bahagian pecahan, mengubah jenis besar menjadi jenis kecil boleh menyebabkan kehilangan data, dan beberapa bahasa tidak membenarkan penukaran langsung jenis tertentu. Pemahaman yang betul tentang peraturan penukaran bahasa membantu mengelakkan kesilapan.
Apakah corak kilang?
Jun 24, 2025 pm 11:29 PM
Mod kilang digunakan untuk merangkum logik penciptaan objek, menjadikan kod lebih fleksibel, mudah dikekalkan, dan ditambah longgar. Jawapan teras adalah: dengan mengurus logik penciptaan objek secara berpusat, menyembunyikan butiran pelaksanaan, dan menyokong penciptaan pelbagai objek yang berkaitan. Keterangan khusus adalah seperti berikut: Mod Kilang menyerahkan penciptaan objek ke kelas kilang khas atau kaedah untuk diproses, mengelakkan penggunaan Newclass () secara langsung; Ia sesuai untuk senario di mana pelbagai jenis objek yang berkaitan dicipta, logik penciptaan boleh berubah, dan butiran pelaksanaan perlu disembunyikan; Sebagai contoh, dalam pemproses pembayaran, jalur, paypal dan contoh lain dicipta melalui kilang -kilang; Pelaksanaannya termasuk objek yang dikembalikan oleh kelas kilang berdasarkan parameter input, dan semua objek menyedari antara muka yang sama; Varian biasa termasuk kilang -kilang mudah, kaedah kilang dan kilang abstrak, yang sesuai untuk kerumitan yang berbeza.


