Java:分隔逗号分隔的字符串,但忽略引号中的逗号

问题:

我有一个字符串模糊地这样:

foo,bar,c;qual="baz,blurb",d;junk="quux,syzygy"

我想用逗号分割 – 但是我需要用引号来忽略逗号。我该怎么做?似乎正则表达式方法失败;我想我可以手动扫描并输入一个不同的模式,当我看到一个报价,但它将是很高兴使用预先存在的库。 (edit:我想我的意思是已经是JDK的一部分的库,或已经是Apache Commons等常用库的一部分。)
上述字符串应分为:

foo
bar
c;qual="baz,blurb"
d;junk="quux,syzygy"

 注意:这不是CSV文件,它是包含在整体结构较大的文件中的单个字符串

回答:

尝试:

public class Main { 
    public static void main(String[] args) {
        String line = "foo,bar,c;qual=\"baz,blurb\",d;junk=\"quux,syzygy\"";
        String[] tokens = line.split(",(?=(?:[^\"]*\"[^\"]*\")*[^\"]*$)", -1);
        for(String t : tokens) {
            System.out.println("> "+t);
        }
    }
}

输出:

> foo
> bar
> c;qual="baz,blurb"
> d;junk="quux,syzygy"

换句话说:split on the comma only if that comma has zero, or an even number of quotes ahead of it
或者,有点友善的眼睛:

public class Main { 
    public static void main(String[] args) {
        String line = "foo,bar,c;qual=\"baz,blurb\",d;junk=\"quux,syzygy\"";

        String otherThanQuote = " [^\"] ";
        String quotedString = String.format(" \" %s* \" ", otherThanQuote);
        String regex = String.format("(?x) "+ // enable comments, ignore white spaces
                ",                         "+ // match a comma
                "(?=                       "+ // start positive look ahead
                "  (?:                     "+ //   start non-capturing group 1
                "    %s*                   "+ //     match 'otherThanQuote' zero or more times
                "    %s                    "+ //     match 'quotedString'
                "  )*                      "+ //   end group 1 and repeat it zero or more times
                "  %s*                     "+ //   match 'otherThanQuote'
                "  $                       "+ // match the end of the string
                ")                         ", // stop positive look ahead
                otherThanQuote, quotedString, otherThanQuote);

        String[] tokens = line.split(regex, -1);
        for(String t : tokens) {
            System.out.println("> "+t);
        }
    }
}

其产生与第一示例相同的。

编辑

正如@MikeFHay在评论中所提到的:

我更喜欢使用Guava’s Splitter,因为它有默认的默认值(参见上面讨论的关于空匹配被String#split()修剪的讨论,所以我做了:

 
 
Code问答: http://codewenda.com/topics/python/
Stackoverflow: Java: splitting a comma-separated string but ignoring commas in quotes

*转载请注明本文链接以及stackoverflow的英文链接

发表评论

电子邮件地址不会被公开。 必填项已用*标注

13 − = 7