1

我必须使用库simpleflatmapper,但我找不到一种方法来简单地用这个库写入csv 文件a 。我可以解析(没有空白行)并存入:List<String[]>List<String[]>

FileReader file = new FileReader("file.csv");
Iterator<String[]> parser = CsvParser.separator(',').quote('\"').iterator(file);
List<String[]> lines = new ArrayList<String[]>();
String[] line;
while(parser.hasNext()) {
    line = parser.next();
    if (line[0].length() != 0) {
        lines.add(line);
    }
}
FileWriter fw = new FileWriter("copy_file.csv");
........

但是我发现没有办法用 .csv 的数据编写一个新的 csv 文件List<String[]> lines。我很确定这是可能的,但没有足够的适当文档。简而言之,我需要帮助!

4

2 回答 2

2

与库的作者讨论之后,这种情况下的理想代码似乎是使用CsvCellWriter(当我们事先不知道要写入的列数,实际上如果我们没有标题)而不是CsvWriter因为CsvWriter需要提前知道要写入的csv文件的结构;线是一个List<String[]>

Maven依赖:

<groupId>org.simpleflatmapper</groupId>
<artifactId>sfm-csv</artifactId>
<version>3.18.3</version>

import org.simpleflatmapper.csv.*;
import org.simpleflatmapper.csv.impl.writer.CsvCellWriter;
..........
FileWriter writer = new FileWriter("new_file.csv");
CsvCellWriter cellWriter = CsvCellWriter.DEFAULT_WRITER.separator(',').quote('"');
lines.forEach ( strs ->  {
try {
    if (strs.length > 0) {
        cellWriter.writeValue(strs[0], writer);
        for (int i = 1; i < strs.length; i++) {
           cellWriter.nextCell(writer);
           cellWriter.writeValue(strs[i], writer);
        }
       }
    cellWriter.endOfRow(writer);
} catch (IOException e) {e.printStackTrace();}
} );
writer.close();

此代码允许写入相同的列表数据,因为我们可以选择分隔符、引号以及最终的其他选项。此外,这个库似乎足够方便和快速地解析 csv 文件。

于 2018-07-13T13:50:14.880 回答
1

从官方文档的首页:

CsvWriter.CsvWriterDSL<String[]> dsl = CsvWriter.from(String[].class)
                                                .columns("a[0]", "a[1]", "a[2]")
                                                .skipHeaders();

try (FileWriter fileWriter = new FileWriter(file)) {
    CsvWriter<String[]> writer = dsl.to(fileWriter);
    lines.forEach(CheckedConsumer.toConsumer(writer::append));
}

我假设每个String[]都至少有三个元素 - columns("a[0]", "a[1]", "a[2]"). 否则,ArrayIndexOutOfBoundsException将发生。

于 2018-07-12T10:05:14.270 回答