使用 OpenCSV 将 CSV 映射到 JavaBean
CSV 文件基本上是纯文本文件,其数据存储在以逗号分隔的列中。OpenCSV 是一个库,用于解析这些 CSV 文件,否则这些文件很难处理。它是一个非常易于使用的库,支持多种功能,例如带有标题的 CSV 文件的读取和写入。
本文将讨论通过 OpenCSV 将 CSV 文件映射到 JavaBean。此外,OpenCSV 是一个有助于此过程的工具。
将 CSV 映射到 JavaBean
OpenCSV 库提供某些类和映射策略,用于将 CSV 文件映射到 Java Bean。一个这样的类是 CSVToBean,它用于将 CSV 文件映射到 JavaBean。为了解析这些 CSV 文件,CSVToBean 类需要一个需要定义并传递给 CSVToBean 类的映射策略。一种流行的映射策略是 HeaderColumnNameTranslateMappingStrategy,它将列 ID 映射到 Java bean 属性。
语法
将 CSV 文件映射到 Bean 是通过一系列步骤完成的。但是,使用列 ID 和 Bean 属性之间映射创建 HashMap 的语法如下:
HashMap map = new HashMap();
map.put("column_id", "bean_property");
首先,我们创建了一个 HashMap,然后使用 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 Bean 的基本步骤。
步骤 3 - 创建一个 HashMap,其中包含列 ID 和 Bean 属性之间的映射。
步骤 4 - 添加 csv 文件中所有与 Bean 属性对应的列 ID。
步骤 5 - 创建 HeaderColumnNameTranslateMappingStrategy 的对象。
步骤 6 - 现在,将映射的 HashMap 传递给 setColumnMapping() 方法。
步骤 7 - 调用 CSVToBean 和 CSVReader 类的对象。
步骤 8 - 现在,我们将调用 CSVToBean 类的解析方法,并将 HeaderColumnNameTranslateMappingStrategy 和 CSVReader 对象传递给它。
步骤 9 - 打印 Bean 对象的详细信息。
方法
现在,让我们使用 OpenCSV 将 Employee.csv 文件的内容映射到 JavaBean。Employee.csv 文件包含员工姓名、部门和工资等数据。
Employee.csv 文件的内容如下:
Employee_Name, Department, Salary Naman, Human Resource, 45000 Nikita, Sales, 35000 Rocky, IT, 50000 Raman, Human Resource, 42000
现在,让我们首先创建 Employee 类,然后创建将此 csv 文件内容映射到 JavaBean 的 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]
如您在上面的程序代码中看到的,我们首先创建了一个 HashMap,用于将列 ID 与相应的 Bean 属性映射。之后,我们为 Employee 类实现了 HeaderColumnNameTranslateMappingStrategy 策略,并将其传递给 CsvToBean 类的 parse 方法,以使用 OpenCSV 将 CSV 映射到 JavaBean。
结论
在本文中,我们学习了如何使用 OpenCSV 将 CSV 文件映射到 JavaBean。讨论的执行此操作的简单技术是使用 CsvToBean 类和一个映射策略,该策略传递给 CsvToBean 类的对象。我们讨论了使用 OpenCSV 将 csv 格式的员工数据解析到 JavaBean 的步骤和程序代码。
数据结构
网络
关系数据库管理系统 (RDBMS)
操作系统
Java
iOS
HTML
CSS
Android
Python
C 编程
C++
C#
MongoDB
MySQL
Javascript
PHP