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]
, будет выдано исключение?
Если да, то как мне анализировать строки, которые не содержат данных в этой позиции текстовой строки?