发布网友 发布时间:2022-04-23 09:11
共3个回答
懂视网 时间:2022-04-23 09:51
这次给大家带来正则的非捕获组与捕获组使用详解,使用正则的非捕获组与捕获组注意事项有哪些,下面就是实战案例,一起来看一下。在一篇正则表达式技术文档中看到下面内容:
“外需要说明的一点是,除(Expression)和(?<name>Expression)语法外,其它的(?...)语法都不是捕获组。”
这个内容是好理解的,但疑惑的是,该文章作者在另一篇相关正则的技术文章中,其中一个这样的实例,着实让我迷惑了一番:
文本内容
<td>a</td><td>b</td>
正则表达式
(?is)<td>(?:(?!</td>).)*</td>
注意上面正则表达式的代码,他对“(?!</td>).”进行“强制非捕获组”,我在短信中告诉他,可以这样写:(?is)<td>((?!</td>).)*</td>
两天仍未见他回复,于是在回过头来研究一下他代码,起初我将重点放在“(?!</td>)”这个括号算不算捕获组。但是在看一次上面技术文章的代码我才反应过来。他不是针对(?!</td>)强制为非捕获组,而是将(?!</td>).强制为非捕获组,于是我就做了下面的测试:
文本内容
<td>a</td><td>a</td>
正则表达式
<td>((?!</td>).)*</td><td>(1)*</td>
匹配结果
<td>a</td><td>a</td>
这就证明,如果不对“(?!</td>).”进行强制为非捕获组,它是会捕获的,而这个捕获,我根本不需要它。
下面,我在测试一下,除了(Expression)和(?<name>Expression)语法外,其它的,如环视,它算不算捕获组。
文本内容
<td>a</td><td>a</td>
正则表达式
<td>((?!</td>).)*</td><td>(2.)*</td>
相信看了本文案例你已经掌握了方法,更多精彩请关注Gxl网其它相关文章!
推荐阅读:
正则表达式怎么匹配图片地址与img标签
使用正则验证用户输入的银行卡号(附代码)
用正则表达式验证判断密码的强弱程度并且进行提示
热心网友 时间:2022-04-23 06:59
这两个正则表达式在匹配的内容上没有区别,都是匹配美元金额(可以是整数或者小数)
只是前一种用的是基本正则符号,后一种用到了非捕获组.
我给你一个php语言的例子,以验证匹配内容没有区别
热心网友 时间:2022-04-23 08:17
相同点:
在不使用引用捕获分组的情况下,两条正则都能从文本中匹配到由“$”开头并且由“.”分割的数字字符串,其实也就是商品价格。 例如从文本:
书名:Python学习手册 价格:$28.88
匹配得到:$28.88
不同处:
如果在使用引用捕获分组的情况下的话,第二条正则可以通过引用编号为1的分组获得匹配字符的前半部分,也就是“$28” 从而忽略之后的小数部分,而第一条正则始终只能完整的匹配整个价格字符。
因为第二条正则使用了非捕获分组在这里也顺便拓展下:
非捕获分组类似普通的捕获分组,只是在开括号后紧跟一个问号和冒号,这样的括号叫做非捕获型括号,它只能限定量词的作用范围,不捕获任何文本。非捕获分组不需要保存匹配的文本,整个表达式的效率也因此提高,但是看起来不如捕获分组美观。