OpenCsv - установить пользовательскую проверку на поле - PullRequest
0 голосов
/ 25 сентября 2019

Я использую OpenCsv для преобразования файла csv в Java Bean.

Мой файл выглядит так:

USER_NAME, USER_ID, FREQUENCY
aaa,111,DAILY
bbb,222,WEEKLY,
ccc,333,MONTHLY
ddd,444,SOME_RANDOM_VALUE
eee,555,YEARLY

Мне нужно применить приведенную ниже проверку для столбцов:

USER_NAME -> not null, alphabets only
USER_ID -> not null, digits only
FREQUENCY -> not null, allowed values - DAILY, WEEKLY, MONTHLY, YEARLY

Для любого другого значения FREQUENCY, зарегистрируйте столбец USER_NAME, как указано ниже: dddd, FREQUENCY

Мне нужно только, чтобы строка была зарегистрирована и поток продолжался как обычно, то есть 'eeee 'должен быть сопоставлен с Java-бином.

Основываясь на Пользовательской логике Opencsv при разборе , я создал следующую логику в Java-бине.

Проблема в том, чтопоток останавливается с помощью «dddd», а «eeee» не отображается.

class UserBean {

    private String userName;
    private String userID;
    private String frequency;

    //Getters and Setters for userName, userID
    public void setFrequency(String frequency) {
        if(frequency.isEmpty() && !(frequency.equalsIgnoreCase("DAILY") && frequency.equalsIgnoreCase("WEEKLY") && frequency.equalsIgnoreCase("MONTHLY") && frequency.equalsIgnoreCase("YEARLY"))) {
            throw new IllegalArgumentException("Invalid value for FREQUENCY"); 
        }
    }
}

public static void main() {

            CsvToBean<UserBean> csvToBean = new CsvToBean<UserBean>();
            Reader reader = new FileReader((File) INPUT_DIR);
            csvToBean = new CsvToBeanBuilder(reader).withSeparator(',')
                    .withType(User.class)
                    .withOrderedResults(true)
                    .withIgnoreLeadingWhiteSpace(true)
                    .build();
            Iterator<PrimeAOBean> csvUserIterator = csvToBean.iterator();

            List<Exception> exceptionList = new ArrayList<Exception>();

            while (csvUserIterator.hasNext()) {
                try {
                UserBean userBean = csvUserIterator.next();
                userDataMap.put(userBean.getUserID(), userBean);
                }
                catch(Exception e) {
                    exceptionList.add(e);
                    continue;
                }
                finally {
                    FileWriter fileWriter = new FileWriter(ERROR_DIR);
                    PrintWriter printWriter = new PrintWriter(fileWriter);
                    for (Exception excep: exceptionList) {
                        printWriter.print(excep.getLocalizedMessage());
                        printWriter.close();
                    }
                    continue;
                }
            }               
                }
...