
本文介绍了如何使用 Java Stream 将从多个 CSV 文件读取的数据进行合并,并保持原始顺序。通过示例代码,详细展示了如何将城市数据和国家数据关联起来,最终为每个城市对象添加对应的国家名称。本文重点在于使用 Stream API 实现高效的数据关联,并提供了一种简洁明了的解决方案。
在处理数据时,经常会遇到需要从多个来源(例如不同的 CSV 文件)读取数据,然后将这些数据合并的需求。本文将以城市和国家数据为例,展示如何使用 Java Stream API 高效地合并这些数据,并保持原始数据的顺序。
假设我们有两个 CSV 文件,分别包含城市和国家的数据。城市数据包含城市ID、城市名称和国家代码,而国家数据包含国家ID、国家名称和国家代码。我们的目标是根据国家代码将城市数据和国家数据关联起来,最终为每个城市对象添加对应的国家名称。
首先,定义城市和国家的实体类:
立即学习“Java免费学习笔记(深入)”;
import com.opencsv.bean.CsvBindByPosition;
public class City {
@CsvBindByPosition(position = 0)
private Integer id;
@CsvBindByPosition(position = 1)
private String name;
@CsvBindByPosition(position = 2)
private String countryCode;
private String countryName; // 新增字段,用于存储国家名称
// getters and setters
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getCountryCode() {
return countryCode;
}
public void setCountryCode(String countryCode) {
this.countryCode = countryCode;
}
public String getCountryName() {
return countryName;
}
public void setCountryName(String countryName) {
this.countryName = countryName;
}
}import com.opencsv.bean.CsvBindByPosition;
public class Country {
@CsvBindByPosition(position = 0)
private Integer id;
@CsvBindByPosition(position = 1)
private String name;
@CsvBindByPosition(position = 2)
private String code;
// getters and setters
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getCode() {
return code;
}
public void setCode(String code) {
this.code = code;
}
}接下来,假设我们已经从 CSV 文件中读取了城市和国家数据,并将它们分别存储在 cities 和 countries 列表中。
import java.util.List;
import java.util.stream.Collectors;
public class DataMerger {
public static void main(String[] args) {
// 假设 cities 和 countries 已经从 CSV 文件中读取
List<City> cities = // 从 CSV 文件读取城市数据
List<Country> countries = // 从 CSV 文件读取国家数据
// 使用 Stream API 合并数据
cities.forEach(city -> city.setCountryName(countries.stream()
.filter(country -> country.getCode().equals(city.getCountryCode()))
.map(Country::getName)
.findAny()
.orElse(null)));
// 打印结果
cities.forEach(city -> System.out.println(city.getName() + " - " + city.getCountryName()));
}
}这段代码使用 forEach 循环遍历城市列表,并使用 Stream API 在国家列表中查找与城市国家代码匹配的国家。找到匹配的国家后,将国家名称设置到城市对象的 countryName 属性中。findAny().orElse(null) 用于处理找不到匹配国家的情况,此时将 countryName 设置为 null。
代码解释:
注意事项:
总结:
本文展示了如何使用 Java Stream API 将从多个 CSV 文件读取的数据进行合并,并保持原始数据的顺序。通过示例代码,详细展示了如何将城市数据和国家数据关联起来,最终为每个城市对象添加对应的国家名称。使用 Stream API 可以简化代码,提高效率,并使代码更易于阅读和维护。
以上就是Java Stream:合并从不同 CSV 文件读取的多个结果的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号