使用 OpenCSV 将 CSV 映射到 JavaBean

2023年 9月 13日 71.7k 0

使用 OpenCSV 将 CSV 映射到 JavaBean

CSV文件基本上是以逗号分隔的列存储数据的纯文本文件。OpenCSV是解析这些CSV文件的库,否则很难处理。它是一个非常易于使用的库,支持读写带有标题的CSV文件等多个功能。

在本文中,我们将讨论通过OpenCSV将CSV文件映射到JavaBeans的过程。此外,OpenCSV是一个在这个过程中有帮助的工具。

将 CSV 映射到 JavaBean

OpenCSV库提供了一些类和映射策略,用于将CSV文件映射到Java Beans。其中一个类是CSVToBean,用于将CSV文件映射到JavaBeans。要解析这些CSV文件,CSVToBean类需要定义并传递给CSVToBean类的映射策略。其中一个流行的映射策略是HeaderColumnNameTranslateMappingStrategy,它将列ID映射到Java Bean属性。

语法

CSV 文件到 Bean 的映射是通过一系列步骤完成的。然而,创建具有列 ID 和梁属性之间的映射的 HashMap 的语法如下 -

HashMap map = new HashMap();
map.put("column_id", "bean_property");

登录后复制

首先,我们创建了一个 hashmap,然后使用 HashMap 的 put() 函数将列 id 与相应的 Java bean 属性进行映射。

算法

  • 第一步 - 首先使用以下依赖项将OpenCSV添加到Java项目中。

对于 Maven 项目,将以下依赖项添加到 java 项目 -

com.opencsv
opencsv
4.1

登录后复制

对于一个Gradle项目,你需要添加以下依赖项 -

compile group: 'com.opencsv', name: 'opencsv', version: '4.1'

登录后复制

  • 第 2 步 - 现在,让我们开始将 csv 文件映射到 Java Bean 的基本步骤。

  • 步骤 3 - 使用列 ID 和 bean 属性之间的映射创建一个 HashMap。

  • 步骤 4 - 添加与 bean 属性对应的 csv 文件的所有列 id。

  • 步骤 5 − 创建 HeaderColumnNameTranslateMappingStrategy 对象。

  • 第 6 步 - 现在,将映射的哈希图传递给 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 的 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 map = new HashMap();
map.put("Employee_Name", "emp_name");
map.put("Department", "department");
map.put("Salary", "salary");
HeaderColumnNameTranslateMappingStrategy s =
new HeaderColumnNameTranslateMappingStrategy();
s.setType(Employee.class);
s.setColumnMapping(map);
CSVReader csvReader = null;
try {
csvReader = new CSVReader(new FileReader
("D:CSVFilesEmployee.csv"));
}
catch (FileNotFoundException e) {
e.printStackTrace();
}
CsvToBean csvToBean = new CsvToBean();
List 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 文件映射到 JavaBean。所讨论的执行此操作的简单技术是使用 CsvToBean 类和传递给 CsvToBean 类的对象的映射策略。我们讨论了使用 OpenCSV 将 csv 格式的员工数据解析为 JavaBean 的步骤和程序代码。

以上就是使用 OpenCSV 将 CSV 映射到 JavaBean的详细内容,更多请关注每日运维网(www.mryunwei.com)其它相关文章!

相关文章

JavaScript2024新功能:Object.groupBy、正则表达式v标志
PHP trim 函数对多字节字符的使用和限制
新函数 json_validate() 、randomizer 类扩展…20 个PHP 8.3 新特性全面解析
使用HTMX为WordPress增效:如何在不使用复杂框架的情况下增强平台功能
为React 19做准备:WordPress 6.6用户指南
如何删除WordPress中的所有评论

发布评论