正则表达式高阶断言

下面是关于正则表达式的断言部分

零宽断言

  • 零宽断言共有四种形式
  • 前两种为正向零宽断言
  • 后两种为负向零宽断言

  • 正向零宽断言

    (?=exp):零宽度正预测先行断言,断言此位置的后面能够匹配exp

    例如[a-z]*(?=ing):匹配以ing结尾的单词的前面部分除了ing以外的部分),先行断言的执行步骤时匹配字符的最右端找到第一个ing,在批评日前面的表达式,若无法匹配则查找第二个ing


    (?<=exp):零宽度正回顾后发断言,断言此位置的前面能够匹配表达式exp

    例如(?<=abc).*匹配以abc开头的字符串的后面部分,若字母为abcdefgh则匹配defgh


    后发断言与先行断言相反,后发要从匹配的字符串的最左端开始查找断言表达式,之后匹配符合条件的后面的字符串,若无法匹配则继续查找第二个断言表达式


  • 负向零宽断言

    (?!exp):零宽度负预测先行断言,断言此位置的后面不能匹配表达式exp,比如\b((?!abc)\w+\b,匹配不包含连续字符出abc的单词,例如abc123,ade123,可以匹配出ade123


    (?:零宽度负回顾后发断言,断言此位置的前面不能匹配表达式exp,例如**(?


总结

  • 正向与负向意义相反
  • 注意正则表达式的语法规范
  • 四种表示都是针对是否可以前后匹配exp的exp周围的内容四种表示都不是匹配exp本身

好啦,上面就是关于断言部分的正则表达式,希望对大家有所帮助!

你可能感兴趣的:(笔记,正则表达式总结,正则表达式,regex)