I was looking at this example from the Super CSV website which shows that dateofbirth is optional column. What happens if i have more than one optional columns? How will the code change than?
private static void readVariableColumnsWithCsvListReader() throws Exception {
final CellProcessor[] allProcessors = new CellProcessor[] { new UniqueHashCode(), // customerNo (must be unique)
new NotNull(), // firstName
new NotNull(), // lastName
new ParseDate("dd/MM/yyyy") }; // birthDate
final CellProcessor[] noBirthDateProcessors = new CellProcessor[] { allProcessors[0], // customerNo
allProcessors[1], // firstName
allProcessors[2] }; // lastName
ICsvListReader listReader = null;
try {
listReader = new CsvListReader(new FileReader(VARIABLE_CSV_FILENAME), CsvPreference.STANDARD_PREFERENCE);
listReader.getHeader(true); // skip the header (can't be used with CsvListReader)
while( (listReader.read()) != null ) {
// use different processors depending on the number of columns
final CellProcessor[] processors;
if( listReader.length() == noBirthDateProcessors.length ) {
processors = noBirthDateProcessors;
} else {
processors = allProcessors;
}
final List<Object> customerList = listReader.executeProcessors(processors);
System.out.println(String.format("lineNo=%s, rowNo=%s, columns=%s, customerList=%s",
listReader.getLineNumber(), listReader.getRowNumber(), customerList.size(), customerList));
}
}
finally {
if( listReader != null ) {
listReader.close();
}
}
}
Also what if the optional columns are not at the end but in center or somewhere else?