使用OpenCSV将CSV映射到JavaBeans
CSV文件基本上是以逗号分隔的列来存储数据的纯文本文件。OpenCSV是解析这些CSV文件的库,否则很难处理。它是一个非常易于使用的库,支持读写带标题的CSV文件等多个功能。
本文将讨论使用OpenCSV将CSV文件映射到JavaBeans。此外,OpenCSV是一种辅助此过程的工具。
将CSV映射到JavaBeans
OpenCSV库提供了特定的类和映射策略,用于将CSV文件映射到Java Beans。其中一个类是CSVToBean,用于将CSV文件映射到JavaBeans。要解析这些CSV文件,CSVToBean类需要定义并传递给CSVToBean类的映射策略。一个常用的映射策略是HeaderColumnNameTranslateMappingStrategy,它将列ID映射到Java Bean属性。
语法
将CSV文件映射到Java Beans是一系列步骤完成的。但是,创建HashMap并在列ID和Java Bean属性之间建立映射的语法如下:
HashMap map = new HashMap();
map.put("column_id", "bean_property");
首先,我们创建了一个哈希映射表,然后使用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 Beans的基本步骤。
-
步骤 3 - 创建一个HashMap,将列ID和bean属性进行映射。
-
步骤 4 - 将csv文件的所有列ID与bean属性进行对应。
-
步骤 5 - 创建HeaderColumnNameTranslateMappingStrategy的对象。
-
步骤 6 - 现在,将映射的hashmap传递给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。
示例: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文件映射到JavaBeans。执行此操作的简单技术是使用CsvToBean类和一种映射策略,该映射策略被传递给CsvToBean类的对象。我们已经讨论了使用OpenCSV将csv格式的员工数据解析为JavaBeans的步骤和程序代码。