superCSvを用いて、それぞれの項目に必須チェック@CsvRequireをしている状況で
空データを取り込んだ場合、エラーが起こらないようなロジックを考えていただけますでしょうか。
読み込むロジック
java
1import com.github.mygreen.supercsv.io.CsvAnnotationBeanReader; 2 3import java.nio.charset.Charset; 4import java.nio.file.Files; 5import java.io.File; 6import java.util.ArrayList; 7import java.util.List; 8 9import org.supercsv.prefs.CsvPreference; 10 11public class Sample { 12 13 // 全レコードを一度に読み込む場合 14 public void sampleReadAll() { 15 16 CsvAnnotationBeanReader<UserCsv> csvReader = new CsvAnnotationBeanReader<>( 17 UserCsv.class, 18 Files.newBufferedReader(new File("sample.csv").toPath(), Charset.forName("Windows-31j")), 19 CsvPreference.STANDARD_PREFERENCE); 20 21 List<UserCsv> list = csvReader.readAll(); 22 23 List<String> errorList = csvReader.getErrorMessages(); 24 25 csvReader.close(); 26 }
アノテーション
java
1@CsvBean 2 public class SampleCsv { 3 4 @CsvColumn(number=1) 5 @CsvRequire 6 private Integer id; 7 8 @CsvColumn(number=2) 9 @CsvRequire(considerBlank=true) 10 private String name; 11 12 // getter/setterは省略 13 }
空データを取り込んだ時にerrorListに2個データが入ると思います。(list<UserCSV>の中身は空)
その後のロジックでerrorListが空でない時はエラーとしています。
冒頭の件を考えていただけますでしょうか。
あなたの回答
tips
プレビュー