
本文介绍了如何使用 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号