限定符
限定符也指数量词(Quantifiers),用来指定正则表达式的一个给定模式必须要出现多少次才能满足匹配
限定符集
字符
描述
*
匹配前面的子表达式零次或多次
例如,zo* 能匹配 "z" 以及 "zoo",* 等价于{0,}
+
匹配前面的子表达式一次或多次
例如,'zo+' 能匹配 "zo" 以及 "zoo",+ 等价于 {1,}
?
匹配前面的子表达式零次或一次
例如,"do(es)?" 可以匹配 "do" 、 "does" ,? 等价于 {0,1}
*?
+?
像 * 和 + 一样匹配前面的模式,但匹配是最小可能匹配
例如,/".*?"/匹配 '"foo" "bar"' 中的 '"foo"'
后面没有 ? 时匹配 '"foo" "bar"'
x(?=y)
只有当
x
后面紧跟着y
时,才匹配x
例如,
/x(?=y)/
只有在 'x' 后面紧跟着 'y' 时,才会匹配它但y不是匹配结果的一部分
x(?!y)
只有当
x
后面不是紧跟着y
时,才匹配x
例如,
/\d+(?!\.)/.exec("3.141")
匹配 141 而不是 3.141
{n}
n 是一个非负整数
匹配确定的 n 次
例如,'o{2}' 不能匹配 "Bob" 中的 'o',匹配 "food" 中的两个 o
{n,}
n 是一个非负整数
至少匹配n 次
例如,'o{2,}' 不能匹配 "Bob" 中的 'o',匹配 "foooood" 中的所有 o
'o{1,}' 等价于 'o+','o{0,}' 则等价于 'o*'
{n,m}
m 和 n 均为非负整数,其中n <= m
最少匹配 n 次且最多匹配 m 次
例如,"o{1,3}" 将匹配 "fooooood" 中的前三个 o
'o{0,1}' 等价于 'o?'
注意在逗号和两个数之间不能有空格
限定符模式
贪婪模式
贪婪模式,指在整个表达式匹配成功的前提下,尽可能多的匹配;贪婪模式的量词:"{m,n}","{m,}","?","*"和"+"
匹配o子表达式零次或多次
匹配o子表达式一次或多次
匹配o子表达式零次或一次
非贪婪模式(最小可能匹配)
非贪婪模式,指在整个表达式匹配成功的前提下,尽可能少的匹配;在贪婪模式量词后加上“?”,即变成非贪婪模式的量词:"{m,n}?","{m,}?","??","*?"和"+?"
判断匹配模式
判断匹配模式指,某个子表达式后是否存在或不存在某个模式,进而进行匹配
x(?=y) x表达式后存在y表达式
x(?!y) x表达式后不存在y表达式
Last updated