Java和Regex,得到一个匹配的子字符串

时间:2013-03-13 19:29:32

标签: java regex pattern-matching

我想匹配以下模式:

[0-9]*-[0-9]*-[BL]

并将模式应用于此字符串:

123-456-L-234

应该成为

123-456-L.

这是我的代码:

HelperRegex{
..
final static Pattern KEY = Pattern.compile("\\d*-\\d*-[BL]");

    public static String matchKey(String key) {
        return KEY.matcher(key).toMatchResult().group(0);
    }

的Junit:

@Test
public final void testMatchKey() {
    Assert.assertEquals("453-04430-B", HelperRegex.matchKey("453-04430-B-1"));
}

发现了一个无匹配的异常抛出。

我已经用“正则表达式教练”证明了我的正则表达式,它似乎没有被破坏,并匹配所有的测试字符串

enter image description here

2 个答案:

答案 0 :(得分:2)

别介意所有这些复杂性。你只需要一行:

String match = input.replaceAll(".*?([0-9]*-[0-9]*-[BL])?.*", "$1");

如果找不到模式,这将产生一个空白字符串。

如果是我,我会在线,甚至没有一个单独的方法。

答案 1 :(得分:1)

您需要使用()创建要检索的组,并确保正则表达式匹配整个字符串(请注意,组0是整个字符串,因此您想要的是组1):

String key = "453-04430-B-1";
Pattern pattern = Pattern.compile("(\\d*-\\d*-[BL]).*");
Matcher m = pattern.matcher(key);
if (m.matches())
    System.out.println(m.group(1)); //prints 453-04430-B