String[] values = line.split(",");
Long locId = Long.parseLong(replaceQuotes(values[0]));
String country = replaceQuotes(values[1]);
String region = replaceQuotes(values[2]);
String city = replaceQuotes(values[3]);
String postalCode = replaceQuotes(values[4]);
String latitude = replaceQuotes(values[5]);
String longitude = replaceQuotes(values[6]);
String metroCode = replaceQuotes(values[7]);
String areaCode = replaceQuotes(values[8]);
//...
public String replaceQuotes(String txt){
txt = txt.replaceAll("\"", "");
return txt;
}
上記のコードを使用して、次の形式のデータで CSV を解析しています。
828,"US","IL","Melrose Park","60160",41.9050,-87.8641,602,708
ただし、次のようなデータ行に遭遇すると、java.lang.ArrayIndexOutOfBoundsException: 7
1,"O1","","","",0.0000,0.0000,,
これは、 の値にアクセスしようとするたびにvalues[7]
例外がスローされるということですか?
もしそうなら、テキスト行のその位置にデータを含まない行を解析するにはどうすればよいですか?