1

温柔点,这是我第一次使用 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();

}

感谢你的协助。

4

2 回答 2

1

你实际上对你的技术有很多顾虑;

  1. 你如何维护列顺序?
  2. 你如何打印列名?
  3. 你如何打印列值?

以下是我的建议。

  1. 维护列顺序。不要使用HashMap,因为它是无序的。相反,使用LinkedHashMap具有“可预测的迭代顺序”(即保持顺序)。

  2. 打印列名。列表中的每一行都包含键值形式的列名,但您只打印列名作为输出的第一行。解决方案是在遍历行之前打印列名。从列表的第一个元素中获取它们。

  3. 打印列值。“billal GHILAS”答案演示了一种打印每行值的方法。

这是一些代码:

try (BufferedWriter writer = Files.newBufferedWriter(
     Paths.get(OUTPUT + "/" + project + "/" + project + ".csv"));)
{
    CSVPrinter csvPrinter = new CSVPrinter(writer,
        CSVFormat.RFC4180.withFirstRecordAsHeader());

    // This assumes that the rowCollection will never be empty.
    // An anonymous scope block just to limit the scope of the variable names.
    {
        HashMap<String, String> firstRow = rowCollection.get(0);
        int valueIndex = 0;
        String[] valueArray = new String[firstRow.size()];

        for (String currentValue : firstRow.values())
        {
            valueArray[valueIndex++] = currentValue;
        }

        csvPrinter.printrecord(valueArray);
    }

    for (HashMap<String, String> row : rowCollection)
    {
        int valueIndex = 0;
        String[] valueArray = new String[row.size()];

        for (String currentValue : row.values())
        {
            valueArray[valueIndex++] = currentValue;
        }

        csvPrinter.printrecord(valueArray);
    }

    csvPrinter.flush();
}
于 2019-11-27T13:00:52.923 回答
0
for (HashMap<String,String> row : rowCollection) {
       Object[] record = new Object[row.size()];
       for (int i = 0; i < columnList.size(); i++) {
            record[i] = row.get(columnList.get(i));
       }

       csvPrinter.printRecord(record);
 }
于 2019-11-27T12:41:23.800 回答