OpenCSV WithVerifier. Проблема с проверкой полей в одной строке.JAVA

Программисты JAVA общаются здесь
Ответить
Anonymous
 OpenCSV WithVerifier. Проблема с проверкой полей в одной строке.

Сообщение Anonymous »

Я пытаюсь выполнить проверку, чтобы проверить, существуют ли в базе данных два поля, указанные в CSV.
Для CSV:
RECORD_TYPE;COD_NATURE;COD_TAXATION
TEST;100001;12;
TEST;100002;12;
TEST;777777;12;

Мне нужно проверить строку 1, если в списке данных существуют 10001 и 12.
Однако при проверке COD_NATURE = 10001 инструмент уже отбрасывает строка 1 и не проверяет столбец COD_TAXATION=12.
Мой код:
CsvToBean csvToBean = new CsvToBeanBuilder(
new FileReader(CSV_FILE_PATH))
.withSeparator(SEPARATOR)
.withType(Layout4010Csv.class)
.withVerifier(new CodNatureVerifier()) //if there is an error here, it already discards the entire line
.withVerifier(new CodTaxation())
.withThrowExceptions(false)
.build();


public class CodNatureVerifier implements BeanVerifier {

@Override
public boolean verifyBean(Layout4010Csv bean) throws CsvConstraintViolationException {

boolean isCodNatureExists = CodNatureRepository.findById(bean.getCodNature()).isPresent();

if (!isCodNatureExists) {
throw new CsvConstraintViolationException(bean);
}

return true;

}
}


public class CodTaxationVerifier implements BeanVerifier {

@Override
public boolean verifyBean(Layout4010Csv bean) throws CsvConstraintViolationException {

boolean isCodTaxationExists = codTaxationRepository.findById(bean.getcodTaxation()).isPresent();

if (!iscodTaxationExists) {
throw new CsvConstraintViolationException(bean);
}

return true;

}
}

При выполнении csvToBean.getCapturedExceptions() я могу перехватывать исключения только в первом столбце CodNatureza и во втором столбце CodTaxation Я не могу, потому что строка уже была удалена.
EDIT:
Я выполнил больше тестов, пытаясь реализовать один класс под названием AllVerifier, но мне это нужно каждый раз, когда я вызываю метод csvToBean.getCapturedExceptions() имеет исключение CsvConstraintViolationException для каждого столбца с ошибкой.
Попытка 1: если он выдает первую ошибку, он даже больше не вводит второе условие.
@Override
public boolean verifyBean(Layout4010Csv bean) throws CsvConstraintViolationException {

boolean isCodNatureExists = codNatureRepository.findById(bean.getCodNature()).isPresent();

if (!isCodNatureExists) {
throw new CsvConstraintViolationException(bean);
}

boolean isCodTaxationExists = codTaxationRepository.findById(bean.getCodTaxation()).isPresent();

if (!isCodTaxationExists ) {
throw new CsvConstraintViolationException(bean);
}

return true;
}

Попытка 2: он даже возвращает, что строка недействительна, но не сообщает мне, какие поля недействительны, поэтому не отвечает.
@Override

public boolean verifyBean(Layout4010Csv bean) throws CsvConstraintViolationException {

boolean isCodNatureExists = codNatureRepository.findById(bean.getCodNature()).isPresent();
boolean isCodTaxationExists = codTaxationRepository.findById(bean.getCodTaxation()).isPresent();

if (!isCodNatureExists || !isCodTaxationExists) {
throw new CsvConstraintViolationException(bean);
}

return true;
}


Подробнее здесь: https://stackoverflow.com/questions/738 ... e-same-row
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «JAVA»