Como converter o seguinte CSV para Hashmap usando JAVA [closed]

0

Suponha que eu tenha um arquivo CSV assim:

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

Eu quero gerar uma saída assim:

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

Todos os Jhon devem se agrupar em 1 mapa e também se o rolo não. é o mesmo, então ele também deve obter o grupo no mesmo mapa.

    
por snoop 23.02.2015 / 07:15

1 resposta

1

Você precisa ter uma lista em um mapa no mapa para fazer isso. O primeiro mapa tem a chave do nome e o mapa interno tem a chave para o lançamento.

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 + "]";
        }
    }
}

Esta saída:

{Jeff={101=[CE=[2]]}, Jhon={121=[US=[3]], 909=[CA=[1], US=[4]]}}
    
por stalet 23.02.2015 / 08:28