最近做微信沃卡项目,有个联通靓号匹配规则,诸如AAA,AA,ABAB,AABB等等类似的号码匹配规则,乍一看,貌似还有小复杂,其实使用正则可以实现轻松匹配。
这里需要用到正则的两个基本知识点
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)/的意思,第一个位置是一个数字(后面跟着和第二个匹配分组一样的)一个数字,前面两个数字(后面跟着和第一个匹配分组就是前面两个数组不等)两个数字(一个数字后面跟着和他一样的一个数字)
说的有点拗口,结合反向引用和零宽断言,我们可以实现很多类似这种靓号逻辑的判断,就不用在辛苦自己写解析器去判断格式了