0

我想要实现的实际上很简单:我的行看起来类似于:

V123,V20  
10,9999  
100,V220  

ETC...

基本上是多对带有前导字母/零的数字。我希望能够使用 RegEx 解析它们,到目前为止我在 Java 中发现的是:

Pattern p = Pattern.compile(".*([1-9](?:\\d{0,2})).*",Pattern.MULTILINE);
Matcher m = p.matcher("V999,V50");
System.out.println(m.matches()); - return true
System.out.println(m.groupCount()); --> this one returns 0

任何帮助将不胜感激,谢谢。

4

2 回答 2

1
public static void main(String[] args) throws IOException {
    String[] a = new String[] {"V123,V20", "10,9999", "100,V220"};

    for (String s: a) {
        Pattern p = Pattern.compile("[\\D0]*(\\d*)[\\D0]*(\\d*)",Pattern.MULTILINE);
        Matcher m = p.matcher(s);
        System.out.println(m.matches());
        System.out.println(m.group(1) + ", " + m.group(2));
    }
}

希望能帮助到你!

编辑

PS:如果有尾随字母,可以在最后加上\\D:

"[\\D0]*(\\d*)[\\D0]*(\\d*)[\\D]*
于 2013-05-13T19:07:31.963 回答
0

我会这样做

    Matcher m = Pattern.compile("\\d+").matcher(str);
    while(m.find()) {
        int i = Integer.parseInt(m.group());
    }
于 2013-05-13T21:00:08.210 回答