如何使用 JAVA 将以下 CSV 转换为 Hashmap

如何使用 JAVA 将以下 CSV 转换为 Hashmap

假设我有这样的 CSV 文件:

Name    Roll No.    Address     PhoneNo
Jhon    909    CA       1
Jeff    101    CE       2
Jhon    121    US      3
Jhon    909    US      4

我想要生成这样的输出:

{Jhon={909={CA=[1],US=[4]},121={US=[3]}}, Jeff={101={CE=[2]}}}

所有的 Jhon 都应该分组到 1 张地图中,而且如果掷骰子号相同,那么也应该分组到同一张地图中。

答案1

您必须在 map in map 中有一个列表才能执行此操作。第一个 map 包含名称的键,而内部 map 包含卷的键。

import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.util.*;

public class Main {

    static Map<String, Map<String, List<Person>>> persons = new HashMap<String, Map<String, List<Person>>>();

    public static void main(String[] args) throws Exception{
        final BufferedReader br = new BufferedReader(new InputStreamReader(Main.class.getClassLoader().getResourceAsStream("stuff.csv")));
        br.readLine(); //Skip the header line
        while(br.ready()){
            add(new Person(br.readLine()));
        }
        System.out.println(persons);
    }

    private static void add(Person person) {
        if(!persons.containsKey(person.getName())){
            persons.put(person.getName(), new HashMap<String, List<Person>>());
        }
        if(!persons.get(person.getName()).containsKey(person.getRoll())){
            persons.get(person.getName()).put(person.getRoll(), new ArrayList<Person>());
        }
        persons.get(person.getName()).get(person.getRoll()).add(person);
    }

    static class Person {

        String name, roll, address, phone;

        public Person(String string) {
            final StringTokenizer tok = new StringTokenizer(string, " ", false);
            name = tok.nextToken();
            roll = tok.nextToken();
            address = tok.nextToken();
            phone = tok.nextToken();
        }

        public String getName() {
            return name;
        }

        public String getRoll() {
            return roll;
        }

        @Override
        public String toString() {
            return address + "=[" + phone + "]";
        }
    }
}

输出:

{Jeff={101=[CE=[2]]}, Jhon={121=[US=[3]], 909=[CA=[1], US=[4]]}}

相关内容