我想匹配以下模式:
[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"));
}
发现了一个无匹配的异常抛出。
我已经用“正则表达式教练”证明了我的正则表达式,它似乎没有被破坏,并匹配所有的测试字符串
答案 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