String, split (",") вряд ли будет работать.
Он разделит поля со встроенными запятыми («Foo, Inc.»), даже если они представляют собой одно поле в строке CSV.
Что делать, если название компании:
Компания, ООО
или хуже:
Хорошая, быстрая и дешевая еда Джо
Согласно Википедии: (http://en.wikipedia.org/wiki/Comma-separated_values)
Поля со встроенными запятыми должны быть заключены в двойные кавычки.
1997,Ford,E350,"Super, luxurious truck"
Поля со встроенными символами двойной кавычки должны быть заключены в символы двойной кавычки, и каждый из встроенных символов двойной кавычки должен быть представлен парой символов двойной кавычки.
1997,Ford,E350,"Super ""luxurious"" truck"
Хуже того, в кавычках могут быть вставлены разрывы строк (новые строки; "\ n"):
Поля со встроенными переносами строк должны быть заключены в двойные кавычки.
1997,Ford,E350,"Go get one now
they are going fast"
Это демонстрирует проблему с String, split (",") анализом запятых:
CSV линия:
a, b, c, "Company, Inc.", d, e, "Joe's", "Хорошее, быстрое и дешевое", "Еда", f, 10/11 / 2010,1 / 1/2011, g , ч, я
// Test String.split(",") against CSV with
// embedded commas and embedded double-quotes in
// quoted text strings:
//
// Company names are:
// Company, Inc.
// Joe's "Good, Fast, and Cheap" Food
//
// Which should be formatted in a CSV file as:
// "Company, Inc."
// "Joe's ""Good, Fast, and Cheap"" Food"
//
//
public class TestSplit {
public static void TestSplit(String s, String splitchar) {
String[] split_s = s.split(splitchar);
for (String seg : split_s) {
System.out.println(seg);
}
}
public static void main(String[] args) {
String csvLine = "a,b,c,\"Company, Inc.\", d,"
+ " e,\"Joe's \"\"Good, Fast,"
+ " and Cheap\"\" Food\", f,"
+ " 10/11/2010,1/1/2011, h, i";
System.out.println("CSV line is:\n" + csvLine + "\n\n");
TestSplit(csvLine, ",");
}
}
Производит следующее:
D:\projects\TestSplit>javac TestSplit.java
D:\projects\TestSplit>java TestSplit
CSV line is:
a,b,c,"Company, Inc.", d, e,"Joe's ""Good, Fast, and Cheap"" Food", f, 10/11/2010,1/1/2011, g, h, i
a
b
c
"Company
Inc."
d
e
"Joe's ""Good
Fast
and Cheap"" Food"
f
10/11/2010
1/1/2011
g
h
i
D:\projects\TestSplit>
Где эта строка CSV должна быть проанализирована как:
a
b
c
"Company, Inc."
d
e
"Joe's ""Good, Fast, and Cheap"" Food"
f
10/11/2010
1/1/2011
g
h
i