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


    最近做微信沃卡项目,有个联通靓号匹配规则,诸如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)/的意思,第一个位置是一个数字(后面跟着和第二个匹配分组一样的)一个数字,前面两个数字(后面跟着和第一个匹配分组就是前面两个数组不等)两个数字(一个数字后面跟着和他一样的一个数字)

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

  • 相关阅读:
    SAR图像处理 MSTAR数据库利用问题
    python 获取系统环境变量 os.environ and os.putenv
    python 模块中的 __init__.py __main__.py
    pylint python2.7 安装记录
    Python--字典
    哈希表
    AC自动机模板
    平衡树(Splay)模板
    矩阵快速幂 模板
    非递归线段树
  • 原文地址:https://www.cnblogs.com/xueduanyang/p/3245545.html
Copyright © 2020-2023  润新知