0

タイトルにあるように、一度に 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";

などですが、他に可能性はありますか?ありがとう。

4

1 に答える 1