scala> val p = "ab|ba|(ab)*a|(ba)*b".r
p: scala.util.matching.Regex = ab|ba|(ab)*a|(ba)*b
scala> val m = p.pattern.matcher _
m: java.lang.CharSequence => java.util.regex.Matcher = <function1>
scala> m("aa").matches
res9: Boolean = false
scala> p.findAllIn("aa").toList
res10: List[String] = List(a, a)
根据res9,“aa”不应匹配。但res10表示有2场比赛。你怎么解释这个?
答案 0 :(得分:4)
aa
将匹配,因为您使用的是find
。
(ab)*a
将匹配a
。
也许你想要一个像这样的表达式:
^(?:ab|ba|(?:ab)*a|(?:ba)*b)$
答案 1 :(得分:4)
你问两件事:
当您使用m("aa").matches
时,您会询问整个字符串aa
是否与模式m
相对应。
当您使用p.findAllIn("aa").toList
时,您询问aa
的子字符串是否与模式m
相对应。
所以,是的,有一些匹配m
的子串,但完整的字符串aa
本身不匹配。