gpt4 book ai didi

java - Apache 公共(public) CSV : quoted input doesn't work

转载 作者:行者123 更新时间:2023-11-29 04:42:57 27 4
gpt4 key购买 nike

import java.io.IOException;
import java.io.StringReader;

import org.apache.commons.csv.CSVFormat;
import org.apache.commons.csv.CSVParser;

我尝试使用 Apache CSV 解析器解析一个简单的 csv 文件。只要我不使用引号,它就可以正常工作。当我尝试在输入中添加引号时

"a";42

它给我错误:

invalid char between encapsulated token and delimiter

下面是一个简单、完整的代码:

public class Test {

public static void main(String[] args) throws IOException {
String DATA = "\"a\";12";
CSVParser csvParser =
CSVFormat.EXCEL
.withIgnoreEmptyLines()
.withIgnoreHeaderCase()
.withRecordSeparator('\n').withQuote('"')
.withEscape('\\').withRecordSeparator(';').withTrim()
.parse(new StringReader(DATA));
}

}

我就是找不到我在代码中遗漏了什么。

最佳答案

这个问题太微不足道了,我错过了。

我使用 withRecordSeparator 而不是 withDelimiter 来设置字段分隔符。

这如我所料:

public class Test {

public static void main(String[] args) throws IOException {
String DATA = "\"a\";12";
CSVParser csvParser =
CSVFormat.EXCEL
.withIgnoreEmptyLines()
.withIgnoreHeaderCase()
.withRecordSeparator('\n').withQuote('"')
.withEscape('\\').withDelimeter(';').withTrim()
.parse(new StringReader(DATA));
}

关于java - Apache 公共(public) CSV : quoted input doesn't work,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38432743/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com