Ответ 1
Общее количество совпадающих групп не зависит от целевой строки ("foo: a b c d"
, в вашем случае), но от шаблона. Ваша модель всегда будет иметь 3 группы:
^([^:]+):(:? ([^ ]+))++$
^ ^ ^
| | |
1 2 3
Группа 1 st будет удерживать ваш ключ, а группа 2 nd которая совпадает с группой 3, но затем включает пробел, всегда будет содержать только 1 ваших значений. Это либо первые значения (в случае ungreedy +?
), либо последнее значение (в случае жадного соответствия).
Что вы можете сделать, это просто совпадение:
^([^:]+):\s*(.*)$
чтобы вы имели следующие совпадения:
- group(1) = "foo"
- group(2) = "a b c d"
а затем разделите группу 2 nd на белые пробелы, чтобы получить все значения:
import java.util.Arrays;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
public class Main {
public static void main (String[] args) throws Exception {
Matcher m = Pattern.compile("^([^:]+):\\s*(.*)$").matcher("foo: a b c d");
if(m.find()) {
String key = m.group(1);
String[] values = m.group(2).split("\\s+");
System.out.printf("key=%s, values=%s", key, Arrays.toString(values));
}
}
}
который будет печатать:
key=foo, values=[a, b, c, d]