详解正则表达式预查?:,?=,?!,?>=
工欲善其事必先利其器,正则表达式无疑是一个非常强大的工具,从txt,excel,word还有众多编辑器,还有各种开发语言都有它的踪影.
下面就说下正则表达式较为高级的预查用法
包含4个关键字符顺序:?<=! (=!只能同时出现一个)
? 预查校验的标志
< 表示方向 存在为反向, 无则正向
! 否定 = 肯定
1.匹配:
()表示捕获分组,()会把每个分组里的匹配的值保存起来,使用$n(n是一个数字,表示第n个捕获组的内容)
(?)表示非捕获分组,和捕获分组唯一的区别在于,非捕获分组匹配的值不会保存起来
2.校验
如果只是校验正则表达式里的预查 ,检查前面后者后面的字符串是否符预查pattern
(?=ex2)ex1 校验exp1是否符合ex2
ex1(?<=ex2) 校验exp1是否符合ex2
(?!ex2) ex1 校验exp1是否不符合ex2
ex1(?<!ex2) 校验exp1是否不符合ex2
eg:
(?![0-9]+$) 预测该位置后面不全是数字
(?!xxxx) 是正则表达式的负向零宽断言一种形式,标识预该位置后不是xxxx字符。
eg2:
河北人".replace(/(?<=中国)人/, "rr") // 匹配河北人中的人,将其替换为rr,结果为 河北rr
"北京人".replace(/(?<=河北)人/, "rr") // 结果为 北京人,因为人前面不是河北,所以无法匹配到