最后再来看一个正则表达式实例的小例子。
上面的正则表达式为:
r\'(.*) are (.*?) .*\'来看下解析:
首先,这是一个字符串,前面的一个 r 表示字符串为非转义的原始字符串,让编译器忽略反斜杠,也就是忽略转义字符。但是这个字符串里没有反斜杠,所以这个 r 可有可无。
(.*) 第一个匹配分组,.* 代表匹配除换行符之外的所有字符。
(.*?) 第二个匹配分组,.*? 后面多个问号,代表非贪婪模式,也就是说只匹配符合条件的最少字符
后面的一个 .* 没有括号包围,所以不是分组,匹配效果和第一个一样,但是不计入匹配结果中。
matchObj.group() 等同于 matchObj.group(0),表示匹配到的完整文本字符。matchObj.group(1) 得到第一组匹配结果,也就是(.*)匹配到的。matchObj.group(2) 得到第二组匹配结果,也就是(.*?)匹配到的。因为只有匹配结果中只有两组,所以如果填 3 时会报错。
好啦,文章到这里就结束了。如果感觉不错的话,请多多点赞支持哦。。。