正则表达式的零宽断言

  • 先行断言   也叫零宽度正预测先行断言(?=表达式)          表示匹配表达式前面的位置
    例如 [a-z]*(?=ing) 可以匹配cooking singing 中的cook与sing
    注意:先行断言的执行步骤是这样的先从要匹配的字符串中的最右端找到第一个ing(也就是先行断言中的表达式)然后 再匹配其前面的表达式,若无法匹配则继续查找第二个ing 再匹配第二个 ing前面的字符串,若能匹配 则匹配
    例如:.*(?=ing) 可以匹配cooking singing 中的cooking sing 而不是 cook

  • 后发断言        也叫零宽度正回顾后发断言        (?<=表达式)   表示匹配表达式后面的位置
    例如(?<=abc).* 可以匹配abcdefg中的defg       
    注意:后发断言跟先行断言恰恰相反 它的执行步骤是这样的:先从要匹配的字符串中的最左端找到第一个abc(也就是先行断言中的表达式)然后 再匹配其后面的表达式,若无法匹配则继续查找第二个abc 再匹配第二个abc后面的字符串,若能匹配 则匹配
    例如(?<=abc).* 可以匹配abcdefgabc中的defgabc 而不是abcdefg

  • 举例:/我爱我(?=老婆)/  这个正则表达式表示匹配“我爱我”这个字符串,且“我爱我”后面跟的是“老婆”,所以可以匹配 “我爱我”后面跟“老婆”的字符串,其它的一律不能匹配,因为这个正则在匹配到“我爱我”的时候它就向后看,就是看“我爱我”的后面是不是跟着“老婆”,只有跟着的时候才能匹配成功,如果是“我爱我小秘”,虽然也能匹配上“我爱我”,但是它后面不是“老婆”,所以匹配不成功。这就是所谓的正向预查。

  • 负向零宽断言 (?!表达式) 也是匹配一个零宽度的位置,不过这个位置的“断言”取表达式的反值,例如 (?!表达式) 表示 表达式 前面的位置,如果 表达式 不成立 ,匹配这个位置;如果 表达式 成立,则不匹配

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