更全面的實例,可以參考
最常用的PHP正則表達式收集整理
http://www.companysz.com/shouce/jiaoben/zhengze/
以下內容為php中常用的正則,正則是一門通用性的語法,可以在網上下載更全面的正則,提供學習!
作用:分割,匹配,查找,替換
1,php中兩個常用的正則函數
preg_match(mode,string subject,array matches);
mode ---模塊,正則的語法
subject ---正則內容
matches ---正則的結果
ereg(mode,string subject,array regs);
以上兩個函數返回的為true或flase。
2,正則表達式包含的元素
一,原子(普通字符:a-z,A-Z,0-9,原子表,轉義符)
二,元字符(有特殊功能的字符)
三,模式修政符(系統內置部分字符i,m,S,U...)
3,正則表達式中的“原子”
一,a-z A-Z_0-9 //最常見的字符
二,(bfw)(sda) //用圓括號包含起來的單元符號,一個括號表示一個整體
三,[sdwe][^mjnb] //用方括號包含起來的原子表,原子表中^代表排除或相反內容
四,轉義字符
/d 包含所有的數字[0-9]
/D 除所有數字外[^0-9]
/w 包含所有英文字符[a-zA-Z_0-9]
/W 除所有英文字符外[^a-zA-Z_0-9] -----匹配特殊字符
/s 包含空白區域 如回車,換行,分頁等[/f/n/r]
4,正則表達式元字符
* 匹配前一個內容的0次或多次
. 匹配內容的0次或多次,但不包含回車換行
+ 匹配前一個內容的1次或多次
? 匹配前一個內容的0次或1次
| 選擇匹配,類似php中||的用法
^ 匹配字符串首部的內容
$ 匹配字符串尾部內容
/b 匹配單詞邊界,邊界可以是空格或者特殊符號
/B 匹配除帶單詞邊界的意外內容
{m} 匹配前一個內容的重復次數為m次
{m,} 匹配前一個內容的重復次數大于等于m次
{m,n} 匹配前一個內容的重復次數m次到n次
() 合并整體匹配,并放入內存,可使用//1//2依次獲取調用
5,正則表達式中的 模式修正符
(1)運算順序
遵循從左到右的的運算規則
()圓括號是最高的 第一優先級
* ? + {} 重復匹配內容 為第二優先級
^ $ /b 邊界處理 為第三優先級
| 條件處理 為第四
最后按照運算順序計算匹配
(2)模式修正符
是為正則表達式增強和補充的一個功能,使用在正則之外
例子:/正則/U U就表示一個模式修正符
一下幾個為php中常用的:(注意:區分大小寫)
i 正則內容在匹配時候不區分大小寫(默認是區分的)
m 在匹配首內容或者尾內容時候采用多行識別匹配
s 將轉義回車取消是為單位匹配如.匹配的時候
x 忽略正則中的空白
A 強制從頭開始匹配
D 強制$匹配尾部任何內容/n
U 禁止貪mei匹配,只跟蹤到最近的一個匹配符并結束,常用在采集程序的正則表達式
例子:
新聞熱點
疑難解答