Чтение данных из файла CSV и распечатка уникальных, дублированных и недействительных данных отдельно

1

У меня есть файл csv, где я должен прочитать файл csv и печатать уникальные, повторяющиеся и недопустимые элементы отдельно. Вот код

import java.io.BufferedReader;
import java.io.FileReader;

import java.util.HashSet;

public class InputData {

    public static void main(String[] args) throws Exception {

        BufferedReader br = new BufferedReader(new FileReader("C:\\Users\\e.csv"));
        String line = null;
        HashSet<String> lines = new HashSet<>();
        HashSet<String> lines1 = new HashSet<>();

        System.out.println("Unique List:-  ");
        while ((line = br.readLine()) != null) 
        {
            {   
            try {
                if (lines.add(line)) {
                    String[] part = line.split(",");
                    Integer.parseInt(part[0]);
                    System.out.println(line);
                } else {
                    lines1.add(line);
                }
            } catch (NumberFormatException ne) {
                System.out.println(" Invalid data:- " + ne); 
            }

            }
        }
        br.close();
        System.out.println("Duplicates:- " +lines1);
    }
}

Если вход

101,Ron,4545,XYZ,3
102,Harry,2345,ABC,3
103,Sam,5448,DEF,3
104,John,9989,GHI,3
101,Ron,4545,XYZ,3
104,John,9989,GHI,3
105,Gang,123,HNB,3
jftdgchj;vcvuigkuj;uygf
hvykfjtucd;gfd;gfd

Я получаю вывод как: -

Unique List:-  
101,Ron,4545,XYZ,3
102,Harry,2345,ABC,3
103,Sam,5448,DEF,3
104,John,9989,GHI,3
105,Gang,123,HNB,3
 Invalid data:- java.lang.NumberFormatException: For input string: "jftdgchj;vcvuigkuj;uygf"
 Invalid data:- java.lang.NumberFormatException: For input string: "hvykfjtucd;gfd;gfd"
Duplicates:- [101,Ron,4545,XYZ,3, 104,John,9989,GHI,3]

Но я хочу дубликаты в отдельных строках... Пожалуйста, помогите

  • 1
    lines1 является HashSet, и вы просто печатаете его с поведением по умолчанию toString (). Зацикливайтесь на заданных элементах, печатая каждый из них.
Теги:
csv

1 ответ

0

Вы используете метод по умолчанию.toString() для HashSet, например, Stephen P, упомянутый в комментарии выше.

Измените это:

System.out.println("Duplicates:- " +lines1);

Для чего-то вроде этого (который использует расширенный цикл for для итерации по набору):

for (String s : lines1) {
    System.out.println("Duplicates:- " + s);
}

Ещё вопросы

Сообщество Overcoder
Наверх
Меню