加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

正则表达式 之贪婪模式

发布时间:2020-12-14 00:42:04 所属栏目:百科 来源:网络整理
导读:贪婪模式 (默认) 直观上是尽可能多的匹配字符 在使用修饰匹配次数的特殊符号时,有几种表示方法可以使同一个表达式能够匹配不同的次数,比如:”{m,n}”,“{m,}”,“?”,“*”,“+”,具体匹配的次数随被匹配的字符串而定。这种重复匹配不定次数的表达式在

贪婪模式 (默认)

直观上是尽可能多的匹配字符

在使用修饰匹配次数的特殊符号时,有几种表示方法可以使同一个表达式能够匹配不同的次数,比如:”{m,n}”,“{m,}”,“?”,“*”,“+”,具体匹配的次数随被匹配的字符串而定。这种重复匹配不定次数的表达式在匹配过程中,总是尽可能多的匹配。
比如,针对文本 “dxxxdxxxd”,举例如下:

(d)(w+)中"w+" 将匹配第一个 "d" 之后的所有字符 "xxxdxxxd"
 http://www.regexlab.com/zh/regref.htm

非贪婪模式

直观上是尽可能少的匹配字符
常用 *?进行限制匹配,不会把后面的字符也吞进去

在修饰匹配次数的特殊符号后再加上一个 “?” 号,则可以使匹配次数不定的表达式尽可能少的匹配,使可匹配可不匹配的表达式,尽可能的 “不匹配”。这种匹配原则叫作 “非贪婪” 模式,也叫作 “勉强” 模式。如果少匹配就会导致整个表达式匹配失败的时候,与贪婪模式类似,非贪婪模式会最小限度的再匹配一些,以使整个表达式匹配成功。
比如,针对文本 “dxxxdxxxd”,举例如下:

(d)(w+?)中 "w+?" 将尽可能少的匹配第一个 "d" 之后的字符,结果是:"w+?" 只匹配了一个 "x"

参考

http://www.regexlab.com/zh/regref.htm

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读