如何使用 CSVWriter 仅在 csv 中嵌入的逗号字符串上使用双引号?

问题描述 投票:0回答:2

这是我在输出 csv 中预期的结果格式:

header1,header2,header3,header4
monica,chandler,"rachel,ross",joey

我目前的结果:

策略1:

CSVWriter csvWriter = new CSVWriter(new FileWriter("D:/new.csv"));
String[] headers = new String[] { "header1", "header2", "header3", "header4"};    
String[] arr = new String[] { "monica", "chandler", "rachel,ross", "joey"};


result:
"header1","header2","header2","header4"
"monica","chandler","rachel,ross","joey"

策略2:

CSVWriter csvWriter = new CSVWriter(new FileWriter("D:/new.csv"), CSVWriter.DEFAULT_SEPARATOR,CSVWriter.NO_QUOTE_CHARACTER, CSVWriter.DEFAULT_ESCAPE_CHARACTER, CSVWriter.DEFAULT_LINE_END);
    String[] headers = new String[] { "header1", "header2", "header3", "header4"};    
    String[] arr = new String[] { "monica", "chandler", "rachel,ross", "joey"};


result:
header1,header2,header2,header4
monica,chandler,rachel",ross,joey

任何人都可以向我建议如何使用 OpenCSV 框架的 CSVWriter 来实现此目的吗?

java spring csv apache-camel opencsv
2个回答
2
投票

您可以使用

CsvWriter::writeNext
方法,该方法还采用
boolean
来指示是始终使用引号,还是仅在需要时使用引号。

来自文档

applyQuotesToAll
- 如果所有值都被引用,则为 True。 False 仅将引号应用于包含分隔符、转义符、引号或换行符的值。

一个例子:

try (CSVWriter csvWriter = new CSVWriter(new FileWriter("new.csv"))) {
    String[] headers = new String[]{"header1", "header2", "header3", "header4"};
    String[] arr = new String[]{"monica", "chandler", "rachel,ross", "joey"};
    csvWriter.writeNext(headers, false);
    csvWriter.writeNext(arr, false);
}

结果:

header1,header2,header3,header4
monica,chandler,"rachel,ross",joey

0
投票

或者,在实例化

CSVWriter
时,您可以定义
CSVWriter.DEFAULT_QUOTE_CHARACTER
(即)
""
,例如,

new CSVWriter(new FileWriter("new.csv"), CSVWriter.DEFAULT_SEPARATOR, CSVWriter.DEFAULT_QUOTE_CHARACTER, CSVWriter.NO_ESCAPE_CHARACTER)

文档参考:这里

© www.soinside.com 2019 - 2024. All rights reserved.