正则表达式的零宽断言
学习.NET的正则表达式时,对零宽断言比较迷惑,拿出时间学习了一下,做个笔记。
零宽断言概述 |
(?<=pattern) (?<!pattern) STRING (?=pattern) (?!pattern) :各种断言出现的相对位置 ?< lookbehind STRING <lookahead :负向 STRING 正向 = :Positive,肯定,表示匹配 ! :Negative,否定,表示不匹配 |
(?=pattern) |
零宽肯定正向预查(Zero-width positive lookahead),非获取匹配,从字符串右侧查找,须匹配pattern。例如,“Windows(?=95|98|NT|2000)”能匹配“Windows2000”中的“Windows”,但不能匹配“Windows3.1”中的“Windows”。预查不消耗字符,即在一个匹配发生后,将继续从STRING之后开始下一次匹配的搜索,而不是从pattern之后开始。下同 |
(?!pattern) |
零宽否定正向预查(Zero-width negative lookahead),非获取匹配,从字符串右侧查找,须不匹配pattern。例如“Windows(?!95|98|NT|2000)”能匹配“Windows3.1”中的“Windows”,但不能匹配“Windows2000”中的“Windows”。 |
(?<=pattern) |
零宽肯定负向预查(Zero-width positive lookbehind),非获取匹配,从字符串左侧查找,须匹配pattern。。例如,“(?<=95|98|NT|2000)Windows”能匹配“2000Windows”中的“Windows”,但不能匹配“3.1Windows”中的“Windows”。 |
(?<!pattern) |
零宽否定负向预查(Zero-width negative lookbehind),非获取匹配,从字符串左侧查找,须不匹配pattern。例如“(?<!95|98|NT|2000)Windows”能匹配“3.1Windows”中的“Windows”,但不能匹配“2000Windows”中的“Windows”。 |