正则表达式中的 .*? 或 .*+ 是什么意思?

正则表达式中的 .*? 或 .*+ 是什么意思?,第1张

一、表示匹配前面的字符0个或多个

二、+表示前面的字符1个或多个

三、?表示放在其他字符后面表示前面的字符可以有,也可以没有,或者放在、+后面表示匹配尽可能少的字符

例如:字符串fooooo,正则fo和fo+会匹配整个字符串,

fo+ 匹配fo,

fo? 匹配f

四、+没有这样的用法,除非是匹配星号本身,即: \+ 表示一个或多个星号

扩展资料:

正则表达式符号

\:

将下一个字符标记符、或一个向后引用、或一个八进制转义符。例如,“\\n”匹配\n。“\n”匹配换行符。序列“\\”匹配“\”而“\(”则匹配“(”。即相当于多种编程语言中都有的“转义字符”的概念。

^:

匹配输入字行首。如果设置了RegExp对象的Multiline属性,^也匹配“\n”或“\r”之后的位置。

$:

匹配输入行尾。如果设置了RegExp对象的Multiline属性,$也匹配“\n”或“\r”之前的位置。

参考资料来源:百度百科-正则表达式

至于::=是“相当于”的意思。

这是用来描述语法的与表达式,在这句之前应该有一段语法的整体框架定义,但是为了增加定义语法的可读性,往往把过于复杂的部分定义语句用占位符代替,比如说本例中的<B>。

然后在后面附加说明(定义)<B>所代表的真正语句,比如说本例中的<Selfconfidence><Stability>。

扩展资料:

正则表达式中部分符号的意思

:匹配前面的子表达式任意次。例如,zo能匹配“z”,也能匹配“zo”以及“zoo”。等价于{0,}。

+:匹配前面的子表达式一次或多次(大于等于1次)。例如,“zo+”能匹配“zo”以及“zoo”,但不能匹配“z”。+等价于{1,}。

:匹配前面的子表达式零次或一次。例如,“do(es)”可以匹配“do”或“does”。等价于{0,1}。

参考资料来源:百度百科-正则表达式

“?:”非获取匹配,匹配冒号后的内容但不获取匹配结果,不进行存储供以后使用。

单独的“?”:匹配前面的子表达式零次或一次。

当“?”紧跟在任何一个其他限制符(,+,,{n},{n,},{n,m})后面时,匹配模式是非贪婪的。非贪婪模式尽可能少地匹配所搜索的字符串,而默认的贪婪模式则尽可能多地匹配所搜索的字符串。

扩展资料

正则表达式是对字符串(包括普通字符(例如,a 到 z 之间的字母)和特殊字符(称为“元字符”)) *** 作的一种逻辑公式,就是用事先定义好的一些特定字符、及这些特定字符的组合,组成一个“规则字符串”,这个“规则字符串”用来表达对字符串的一种过滤逻辑。正则表达式是一种文本模式,模式描述在搜索文本时要匹配的一个或多个字符串。

参考资料来源:百度百科:正则表达式


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/13351024.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-07-19
下一篇 2023-07-19

发表评论

登录后才能评论

评论列表(0条)

保存