温柔点,这是我第一次使用 Apache Commons CSV 1.7。
我正在创建一个服务来处理一些 CSV 输入,从外部来源添加一些额外的信息,然后写出这个 CSV 以摄取到另一个系统中。
我将收集到的信息存储到
HashMap<String, String>
最终输出 csv 的每一行的列表中。Hashmap 包含<ColumnName, Value for column>
.
我在使用 CSVPrinter 将 HashMaps 的值正确分配到行中时遇到问题。我可以将值连接成一个字符串,变量之间有逗号;但是,这只是将整个字符串插入第一列。
我无法定义或硬编码标头,因为它们是从配置文件中获得的,并且可能会根据使用该服务的项目而改变。
这是我的一些代码:
try (BufferedWriter writer = Files.newBufferedWriter(
Paths.get(OUTPUT + "/" + project + "/" + project + ".csv"));)
{
CSVPrinter csvPrinter = new CSVPrinter(writer,
CSVFormat.RFC4180.withFirstRecordAsHeader());
csvPrinter.printRecord(columnList);
for (HashMap<String, String> row : rowCollection)
{
//Need to map __record__ to column -> row.key, value -> row.value for whole map.
csvPrinter.printrecord(__record__);
}
csvPrinter.flush();
}
感谢你的协助。