正則表達式是一種描述字符串結果的語法規則,是一個特定的格式化模式,可以匹配、替換、截取匹配的字符串。常用的語言基本上都有正則表達式,如JavaScript、Java等。其實,只有了解一種語言的正則使用,其他語言的正則使用起來,就相對簡單些。文本主要圍繞解決下面問題展開。
① 有哪些常用的轉義字符
② 什么是限定符與定位符
③ 什么是單詞定位符
④ 特殊字符有哪些
⑤ 什么是逆向引用以及怎樣使用逆向引用
⑥ 匹配模式
⑦ php中怎樣使用正則表達式
⑧ php中哪些方面需要用到正則
⑨ 怎樣進行郵箱匹配,url匹配,手機匹配
⑩ 怎樣使用正則替換字符串中某些字符
⑪ 貪婪匹配與惰性匹配區別
⑫ 正則表達式之回溯與固態分組
⑬ 正則優缺點有哪些
正則表達式的基本知識匯總
行定位符(^與$)
行定位符是用來描述字符串的邊界。“$”表示行結尾“^”表示行開始如"^de",表示以de開頭的字符串 "de$",表示以de結尾的字符串。
單詞定界符
我們在查找的一個單詞的時候,如an是否在一個字符串”gril and body”中存在,很明顯如果匹配的話,an肯定是可以匹配字符串“gril and body”匹配到,怎樣才能讓其匹配單詞,而不是單詞的一部分呢?這時候,我們可以是喲個單詞定界符\b。
\ban\b 去匹配”gril and body”的話,就會提示匹配不到。
當然還有一個大寫的\B,它的意思,和\b正好相反,它匹配的字符串不能使一個完整的單詞,而是其他單詞或字符串中的一部分。如\Ban\B。
選擇字符(|) ,表示或
選擇字符表示或的意思。如Aa|aA,表示Aa或者是aA的意思。注意使用”[]”與”|”的區別,在于”[]”只能匹配單個字符,而”|”可以匹配任意長度的字符串。在使用”[]”的時候,往往配合連接字符”-“一起使用,如[a-d],代表a或b或c或d。
排除字符,排除操作
正則表達式提供了”^”來表示排除不符合的字符,^一般放在[]中。如[^1-5],該字符不是1~5之間的數字。
限定符(?*+{n,m})
限定符主要是用來限定每個字符串出現的次數。
限定字符 含義如(D+)表示一個或多個D
點號操作符
匹配任意一個字符(不包含換行符)
表達式中的反斜杠(\)
表達式中的反斜杠有多重意義,如轉義、指定預定義的字符集、定義斷言、顯示不打印的字符。
轉義字符
轉義字符主要是將一些特殊字符轉為普通字符。而這些常用特殊字符有”.”,”?”、”\”等。
指定預定義的字符集
字符 含義###顯示不可打印的字符
字符 含義括號字符()
在正則表達式中小括號的作用主要有:
改變限定符如(|、* 、^)的作用范圍
如(my|your)baby,如果沒有”()”,|將匹配的是要么是my,要么是yourbaby,有了小括號,匹配的就是mybaby或yourbaby。
進行分組,便于反向引用
反向引用
反向引用,就是依靠子表達式的”記憶”功能,匹配連續出現的字串或是字符。如(dqs)(pps)\1\2,表示匹配字符串dqsppsdqspps。在下面php應用中,我將詳細展開學習反向引用。
模式修飾符