假设我有这样的 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]]}}