正則表達式:(.+)和(.+?)的區別


1、符號釋義

① ()  分組符,把括號內的字符當成一個整體處理。

②   與換行符外的字符都匹配,針對單字符。

+ 前一字符必須存在,可以重復1次或更多次

④ 跟在子串后,表示匹配前面的子串1次或0次,即前一字符可以存在也可以不存在,但是存在只能有一次;

        跟在*、+、?后,表示進入非貪婪模式,也稱為惰性模式。

 

2、貪婪/非貪婪模式

*正則默認貪婪模式

貪婪模式

盡可能匹配最長的字符串。貪婪匹配是先看整體字符串是否匹配,如果不匹配,它會去掉字符串中的最后一個字符再次嘗試匹配。以此循環,直至匹配成功。

非貪婪模式

盡可能匹配最短的字符串。惰性匹配是從左側第一個字符向右匹配,先看是否匹配,若不匹配,就加入右側下一個字符再次嘗試匹配。以此循環,直至匹配成功。

 

3、實例

存在字符串"<1><123>"

①正則表達式<(.+)>表示盡可能匹配最長的符合規則<字符串>的內容,最終返回"<1><123>"

②正則表達式<(.+?)>表示盡可能匹配最短的符合規則<字符串>的內容,最終返回"<1>"


免責聲明!

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



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