使用 Apache Commons CSV 阅读以下 TSV 片段时:
Name DOB SIN Address, contact information
"Patience Middleton" "18-4-87" 720463771 "varius Cras sem aliquam taciti fames hendrerit tempor"
这是我的代码:
CSVFormat format = CSVFormat.newFormat('\t').withQuote('"');
CSVParser parsed = CSVParser.parse(csvData, format);
List<CSVRecord> record = parsed.getRecords();
System.out.println(parsed.getHeaderMap().toString());
但是我总是得到一个
NullPointerException
说明 parsed.getHeaderMap() == null
。根据 API ( https://commons.apache.org/proper/commons-csv/apidocs/org/apache/commons/csv/CSVParser.html ),该方法可能会返回按列顺序迭代的标题映射的副本。
我的代码或 CSV 文件有问题吗?图书馆不好吗?
最佳答案
默认情况下,CSVParser
假定没有标题行,并将第一行解析为常规数据。您需要明确地告诉它,您希望通过在withHeader()
上调用 CSVFormat
来将CSV文件的第一行解释为标题:
CSVParser parsed = CSVParser.parse(csvData,
CSVFormat.newFormat('\t').withQuote('"').withHeader());