1、符號釋義
① () 分組符,把括號內的字符當成一個整體處理。
② . 與換行符外的字符都匹配,針對單字符。
③ + 前一字符必須存在,可以重復1次或更多次
④ ?跟在子串后,表示匹配前面的子串1次或0次,即前一字符可以存在也可以不存在,但是存在只能有一次;
跟在*、+、?后,表示進入非貪婪模式,也稱為惰性模式。
2、貪婪/非貪婪模式
*正則默認貪婪模式
①貪婪模式
盡可能匹配最長的字符串。貪婪匹配是先看整體字符串是否匹配,如果不匹配,它會去掉字符串中的最后一個字符再次嘗試匹配。以此循環,直至匹配成功。
②非貪婪模式
盡可能匹配最短的字符串。惰性匹配是從左側第一個字符向右匹配,先看是否匹配,若不匹配,就加入右側下一個字符再次嘗試匹配。以此循環,直至匹配成功。
3、實例
存在字符串"<1><123>"
①正則表達式<(.+)>表示盡可能匹配最長的符合規則<字符串>的內容,最終返回"<1><123>"
②正則表達式<(.+?)>表示盡可能匹配最短的符合規則<字符串>的內容,最終返回"<1>"