巧用正则零宽断言实现靓号检索逻辑

最近做微信沃卡项目,有个联通靓号匹配规则,诸如AAA,AA,ABAB,AABB等等类似的号码匹配规则,乍一看,貌似还有小复杂,其实使用正则可以实现轻松匹配。

image

这里需要用到正则的两个基本知识点

1. 反向引用,\1,\2分表表示第一个第二个正则子表达式捕获分组

2. 零宽断言,度娘传送门http://baike.baidu.com/view/5201192.htm

注意,js语言的正则中只有?!负向预查和?=正向预查,没有?<= 而这两个都是非捕获

再来看我们的例子

AAA的正则/(\d)(?=\1)(\d)(?=\1)\d/的意思,第一个位置是一个数字(后面跟着和第一个匹配分组一样的)一个数字(后面跟着和第一个匹配分组一样的)一个数字

AABB的正则/((\d)(?=\2)\d)(?!\1)((\d)(?=\4)\d)/的意思,第一个位置是一个数字(后面跟着和第二个匹配分组一样的)一个数字,前面两个数字(后面跟着和第一个匹配分组就是前面两个数组不等)两个数字(一个数字后面跟着和他一样的一个数字)

 

说的有点拗口,结合反向引用和零宽断言,我们可以实现很多类似这种靓号逻辑的判断,就不用在辛苦自己写解析器去判断格式了

你可能感兴趣的:(正则)