0
У меня есть данные таблицы в формате CSV. Первая строка содержит имена всех столбцов (ключи) и все последующие строки являются записи (значения), как показано ниже:Вставка значений в LinkedHashMap без использования ключа
ID,Name,Contact,Address
1,Alex,987654321,CA USA
2,Bob,4489398,LA USA
3,Marley,7236487,Washington
Я читаю этот файл и пытаюсь хранить записи как ключевая пару значения в LinkedHashMap. Вот мой код, чтобы показать, что я пытаюсь сделать. Мой вопрос написан в коде как комментарий.
public static void readCSV() throws IOException {
BufferedReader br = new BufferedReader(new FileReader("table.csv"));
Map<String, ArrayList<String>> map = new LinkedHashMap<>();
String line = br.readLine();
String[] keys = line.split(",");
/*insert all keys with a corresponding empty arraylist as value to store
all values of a particular key. ie each arralist will contain all values
of individual columns. Since it is a linkedhashmap, keys are stored in
same order as they appear in the csv file*/
for (String key : keys) {
map.put(key, new ArrayList<String>());
}
while((line = br.readLine())!=null){
String[] values = line.split(",");
for (String value : values) {
/*here I want to get the arraylists sequentially to store value.
I know the first value goes in the first arraylist, second goes
to second arraylist and so on.
Is there a way to do this without using the key here??
*/
}
}
}
Почему эта структура данных, а не ключ карта -> ColumnIndex и список 'String []' (один за строку)? – fabian
Может быть лучше разобрать каждую строку на пользовательский объект и поместить их в список. – davioooh