Разбор файла CSV и отображение конкретной информации в hashmap коллекции java - PullRequest
0 голосов
/ 24 октября 2019

Я практикую Java, что является новым для меня и недавно узнал о коллекциях в Java. Я хочу проанализировать CSV-файл и сохранить его на hashmap. Кроме того, я не хочу использовать какой-либо парсер.

Мой CSV файл: -

id,date,ministry,questions
2011,15.02.2014,HEALTH,What was the outcome
20757,24.02.2015,"DEFENCE , FINANCE" ,"Your budget this year .."
20113,17.03.2013,HEALTH, Hospitals build

Итак, у меня есть несколько вопросов: -

  • Я хочу, чтобы "DEFENCE , FINANCE" в том же столбце. Как я буду использовать regex для удаления ",", чтобы разделитель не устанавливал новый столбец
  • Я хочу отображать количество вопросов, задаваемых в каждом министерском департаменте. Здесь ex: - У ЗДОРОВЬЯ есть всего 2 вопроса и т. Д.
  • Также нет дубликатов.

Я анализирую через устройство чтения файлов ввода / вывода.

Мой код: -

public class MainData {

    public static void main(String[] args) throws IOException ,FileNotFoundException{

        String line = "";
        String cvsSplitBy = ",";

    try{
        BufferedReader br = new BufferedReader(new FileReader("src/main/resources/rj.csv"));
        HashMap<String,String> rjFile = new HashMap<String, String>();
        System.out.println("running"+rjFile);


        while ((line = br.readLine()) != null) {

            String[] rj = line.split(cvsSplitBy);

            System.out.println(br);
        }
    } catch (IOException e) {
        e.printStackTrace();
    }
    }
}

PS: - Я хочу использовать только связанные с картой коллекции.

1 Ответ

1 голос
/ 24 октября 2019

Вот простой пример для начала. Я поставил оба подхода (список вопросов и количество вопросов). Выберите тот, который соответствует вашим потребностям, и удалите другой или используйте оба:

import java.io.BufferedReader;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.io.IOException;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

public class MainData {
    public static void main(String[] args) throws IOException, FileNotFoundException {
        String line = "";
        String cvsSplitBy = ",(?=(?:[^\"]*\"[^\"]*\")*[^\"]*$)";

        try {
            BufferedReader br = new BufferedReader(new FileReader("src/main/resources/rj.csv"));
            Map<String, List<String>> questListByMinistry = new HashMap<>();
            Map<String, Integer> questCountByMinistry = new HashMap<>();
            //skip the first line (header)
            br.readLine();
            while ((line = br.readLine()) != null) {
                String[] rj = line.split(cvsSplitBy);

                if(!questCountByMinistry.containsKey(rj[2])){
                    //if the ministry doesn't exist as key yet put it to your map and put the value 1
                    questCountByMinistry.put(rj[2], 1);
                }
                else{
                    //else if it already exist get the current value and add +1
                    questCountByMinistry.put( rj[2], questCountByMinistry.get(rj[2])+1);
                }

                //-----------------------------------------------

                if(!questListByMinistry.containsKey(rj[2])){
                    //if key doesen't exist put it to map and create a new list                    
                    questListByMinistry.put(rj[2], new ArrayList<>());
                    // and add the question to the list
                    questListByMinistry.get(rj[2]).add(rj[3]);
                }
                else{
                    //else if key already exists get the list associated to key and add the question
                    questListByMinistry.get(rj[2]).add(rj[3]);
                }                
            }
            System.out.println(questCountByMinistry);
            System.out.println(questListByMinistry);
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}

Если вы используете Java8 или выше / Если вы хотите познакомиться с возможностями Java8

,приведенный выше код может быть переписан на:

public static void main(String[] args) throws IOException, FileNotFoundException {
    String line = "";
    String cvsSplitBy = ",(?=(?:[^\"]*\"[^\"]*\")*[^\"]*$)";

    try {
        BufferedReader br = new BufferedReader(new FileReader("src/main/resources/rj.csv"));
        Map<String, List<String>> questListByMinistry = new HashMap<>();
        Map<String, Integer> questCountByMinistry = new HashMap<>();
        //skip the first line 
        br.readLine();
        while ((line = br.readLine()) != null) {
            String[] rj = line.split(cvsSplitBy);
            questListByMinistry.computeIfAbsent(rj[2], k -> new ArrayList<>()).add(rj[3]);
            questCountByMinistry.compute(rj[2], (k,v) -> v==null? 1 : v+1);                    
        }
        System.out.println(questCountByMinistry);
        System.out.println(questListByMinistry);
    } catch (IOException e) {
        e.printStackTrace();
    }
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...