正則表達式的零寬斷言


學習.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”。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM