タイトルにあるように、一度に 2 つのファイルを読み取ることができる Super CSV の可能性があります。次のコードは、1 つの file.csv の例を示しています。
public class Reading {
private static final String CSV_FILENAME1 = "src/test/resources/test1/customers.csv";
public static void partialReadWithCsvMapReader() throws Exception {
ICsvMapReader mapReader1 = null;
try {
mapReader1 = new CsvMapReader(new FileReader(CSV_FILENAME1), CsvPreference.STANDARD_PREFERENCE);
mapReader1.getHeader(true);
final String[] header = new String[] { "customerNo", "firstName", "lastName", null, null, null, null, null,
null, null, "TOMEK" };
final CellProcessor[] processors = new CellProcessor[] { new UniqueHashCode(), new NotNull(),
new NotNull(), new NotNull(), new NotNull(), new Optional(), new Optional(), new NotNull(),
new NotNull(), new LMinMax(0L, LMinMax.MAX_LONG), new NotNull()};
Map<String, Object> customerMap;
while( (customerMap = mapReader1.read(header, processors)) != null ) {
System.out.println(String.format("lineNo=%s, rowNo=%s, customerMap=%s", mapReader1.getLineNumber(),
mapReader1.getRowNumber(), customerMap));
}
}
finally {
if( mapReader1 != null ) {
mapReader1.close();
}
}
}
}
1 つの解決策は、2 番目の変数 CSV_FILENAME2 を宣言することです。
private static final String CSV_FILENAME1 = "src/test/resources/test1/customers.csv";
などですが、他に可能性はありますか?ありがとう。