Я пытаюсь прочитать csv и добавить поля в структуру данных. Но одна из строк не сформирована должным образом, и я это знаю. Я просто хочу пропустить строку и перейти к другой. Но, хотя я уловил исключение, он все еще прерывает цикл. Любая идея, что мне здесь не хватает?skip malformed csv row
Мой CSV:
"id","name","email"
121212,"Steve","[email protected]"
121212,"Steve","[email protected]",,
121212,"Steve","[email protected]"
Мой код:
import com.fasterxml.jackson.databind.MappingIterator;
import com.fasterxml.jackson.dataformat.csv.CsvMapper;
import com.fasterxml.jackson.dataformat.csv.CsvSchema;
public static void main(String[] args) throws Exception{
Path path = Paths.get("list2.csv");
CsvMapper mapper = new CsvMapper();
CsvSchema schema = CsvSchema.emptySchema().withHeader();
MappingIterator<Object> it = mapper.reader(Object.class)
.with(schema)
.readValues(path.toFile());
try{
while(it.hasNext()){
Object row;
try{
row = it.nextValue();
} catch (IOException e){
e.printStackTrace();
continue;
}
}
} catch (ArrayIndexOutOfBoundsException e){
e.printStackTrace();
}
}
Исключение:
com.fasterxml.jackson.core.JsonParseException: Too many entries: expected at most 3 (value #3 (0 chars) "")
at [Source: [email protected]; line: 3, column: 38]
at com.fasterxml.jackson.core.JsonParser._constructError(JsonParser.java:1486)
at com.fasterxml.jackson.core.base.ParserMinimalBase._reportError(ParserMinimalBase.java:518)
at com.fasterxml.jackson.dataformat.csv.CsvParser._handleNextEntryExpectEOL(CsvParser.java:601)
at com.fasterxml.jackson.dataformat.csv.CsvParser._handleNextEntry(CsvParser.java:587)
at com.fasterxml.jackson.dataformat.csv.CsvParser.nextToken(CsvParser.java:474)
at com.fasterxml.jackson.databind.deser.std.UntypedObjectDeserializer$Vanilla.mapObject(UntypedObjectDeserializer.java:592)
at com.fasterxml.jackson.databind.deser.std.UntypedObjectDeserializer$Vanilla.deserialize(UntypedObjectDeserializer.java:440)
at com.fasterxml.jackson.databind.MappingIterator.nextValue(MappingIterator.java:188)
at CSVTest.main(CSVTest.java:24)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:606)
at com.intellij.rt.execution.application.AppMain.main(AppMain.java:140)
java.lang.ArrayIndexOutOfBoundsException: 3
at com.fasterxml.jackson.dataformat.csv.CsvSchema.column(CsvSchema.java:941)
at com.fasterxml.jackson.dataformat.csv.CsvParser._handleNamedValue(CsvParser.java:614)
at com.fasterxml.jackson.dataformat.csv.CsvParser.nextToken(CsvParser.java:476)
at com.fasterxml.jackson.databind.MappingIterator.hasNextValue(MappingIterator.java:158)
at CSVTest.main(CSVTest.java:21)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:606)
at com.intellij.rt.execution.application.AppMain.main(AppMain.java:140)
Какое исключение выбрасывается? Измените свой вопрос, чтобы включить трассировку стека. – dsh
за то, что стоит, во время моего исследования я обнаружил некоторые проблемы, которые могут быть связаны с проблемой, с которой я сталкиваюсь. https://github.com/FasterXML/jackson-dataformat-csv/issues/52 – notacyborg