正則表達(dá)式的基本知識(shí):
元字符:
正則表達(dá)式的威力在于其能夠在模式中包含選擇和循環(huán)。它們通過(guò)使用
有兩組不同的元字符:一種是模式中除了方括號(hào)內(nèi)都能被識(shí)別的,還有一種是在方括號(hào)內(nèi)被識(shí)別的。方括號(hào)之外的元字符有這些:
有數(shù)種用途的通用轉(zhuǎn)義符
斷言目標(biāo)的開頭(或在多行模式下行的開頭,即緊隨一換行符之后)
斷言目標(biāo)的結(jié)尾(或在多行模式下行的結(jié)尾,即緊隨一換行符之前)
匹配除了換行符外的任意一個(gè)字符(默認(rèn)情況下)
字符類定義開始
字符類定義結(jié)束
開始一個(gè)多選一的分支
子模式開始
子模式結(jié)束
擴(kuò)展 ( 的含義,也是 0 或 1 數(shù)量限定符,以及數(shù)量限定符最小值
匹配 0 個(gè)或多個(gè)的數(shù)量限定符
匹配 1 個(gè)或多個(gè)的數(shù)量限定符
最少/最多數(shù)量限定開始
最少/最多數(shù)量限定結(jié)束
模式中方括號(hào)內(nèi)的部分稱為“字符類”。字符類中可用的元字符為:
通用轉(zhuǎn)義字符
排除字符類,但僅當(dāng)其為第一個(gè)字符時(shí)有效
指出字符范圍
結(jié)束字符類
更加詳細(xì)的每個(gè)元字符的使用方法請(qǐng)參照PHP手冊(cè)的:模式語(yǔ)法 一節(jié)。
看一些例子來(lái)講算法:(引自:http://php.mydict.com/ziliao/4/15/2006_06/PHPZhongDeZhengZeBiaoDaShi3539_1.html)
K特殊字符”^”用來(lái)匹配以指定字符串開頭的字符串。例如:
KKKK”^hello” :這個(gè)模式與字符串”hello,PHP world!”匹配,但是與”Say hello to you”不匹配。
KK特殊字符”$”用來(lái)匹配以指定字符串結(jié)尾的字符串。例如:
KKKK”you$” :這個(gè)模式與”How are you”匹配,與”your”不匹配。
KK當(dāng)特殊字符”^”和”$”同時(shí)使用時(shí),表示精確匹配。例如:
KKKK”^hello$” :這個(gè)模式只匹配字符串”hello”。
KK如果一個(gè)模式不包括”^”和”$”,那么它與任何包含該模式的字符串匹配。例如: KKKK”you” :與字符串”What is your name?”是匹配的。
KK在該模式中的字母只是普通的字符,數(shù)字也是一樣的。
KK如果要用到其他一些稍微復(fù)雜的字符,如標(biāo)點(diǎn)符號(hào)和空白字符(比如空格、制表符等),就要要用到轉(zhuǎn)義序列。所有的轉(zhuǎn)義序列都用反斜杠(“”)打頭,例如制表符的轉(zhuǎn)義序列是:”t”。所以如果我們要檢測(cè)一個(gè)字符串是否以制表符開頭,可以用這個(gè)模式:
KKKK”^t”
KK類似的,用”n”表示換行,”r”表示回車,反斜杠本身用”\”表示,句號(hào)”.”用”.”表示,依此類推。
KK如何使用字符簇?
KK如果要判斷用戶輸入的電話號(hào)碼、地址、EMAIL地址、信用卡號(hào)碼等是否有效,用普通的基于字面的字符串比較是不夠的。所以要用一種更好的方法來(lái)描述我們想要的模式,這就是字符簇。
KK比如,要建立一個(gè)表示所有元音字符的字符簇,就可以這樣做:
KKKK”[AaEeIiOoUu]” :這個(gè)模式與任何元音字符匹配,但只能表示一個(gè)字符。
KK用特殊符號(hào)”-“可以表示一個(gè)字符的范圍,如:
“[a-z]” //匹配字母a-z,即所有的小寫字母
“[A-Z]” //匹配字母A-Z,即所有的大寫字母
“[a-zA-Z]” //匹配所有的字母
“[0-9]” //匹配所有的數(shù)字
“[0-9.-]” //匹配所有的數(shù)字,以及句號(hào)和減號(hào)
“[ frtn]” //匹配所有的白字符
KK同樣的,這些也只匹配一個(gè)字符。
KK如果要匹配由一個(gè)小寫字母和一位數(shù)字組成的字符串,比如”a4″、”b5″或”f1″,但不是”aa4″、”b5a4″ 或”f12″的話,用這個(gè)模式:
KKKK”^[a-z][0-9]$”
KK盡管[a-z]代表26個(gè)字母的范圍,但在這里它只能與第一個(gè)字符是小寫字母的字符串匹配。
KK我們已經(jīng)知道”^”表示字符串的開頭,但是當(dāng)在一組方括號(hào)里使用”^”時(shí),它表示”非”或”排除”的意思,常常用來(lái)剔除某個(gè)字符。還用前面的例子,我們要求第一個(gè)字符不能是數(shù)字: KKKK”^[^0-9][0-9]$”
KK這個(gè)模式與”a4″、”b5″及”+2″是匹配的,但與”12″、”66″是不匹配的。下面是幾個(gè)排除特定字符的例子:
KKKK”[^a-z]” //除了小寫字母以外的所有字符
KKKK”[^\/^]” //除了()(/)(^)之外的所有字符
KKKK”[^”‘]” //除了雙引號(hào)(“)和單引號(hào)(‘)之外的所有字符
KK特殊字符”.” (點(diǎn),英文句號(hào))在正規(guī)表達(dá)式中用來(lái)匹配除了”換行”之外的所有字符。所以模式”^.5$”與任何兩個(gè)字符的、以數(shù)字5結(jié)尾和以其他非”換行”字符開頭的字符串匹配。模式”.”可以匹配任何字符串,除了空串和只包括一個(gè)”換行”的字符串。
KKPHP的正規(guī)表達(dá)式有一些內(nèi)置的通用字符簇,列表如下:
字符簇 含義
“[[:alpha:]]” 任何字母
“[[:digit:]]” 任何數(shù)字
“[[:alnum:]]” 任何字母和數(shù)字
“[[:space:]]” 任何白字符
“[[:upper:]]” 任何大寫字母
“[[:lower:]]” 任何小寫字母
“[[:punct:]]” 任何標(biāo)點(diǎn)符號(hào)
“[[:xdigit:]]” 任何16進(jìn)制的數(shù)字,相當(dāng)于[0-9a-fA-F]
KK如何匹配重復(fù)出現(xiàn)的情況?
KK在很多的情況下,我們可能要匹配一個(gè)單詞或一組數(shù)字。一個(gè)單詞有若干個(gè)字母組成,一組數(shù)字有若干個(gè)單一的數(shù)字組成。我們用跟在字符或字符簇后面的花括?quot;{}”來(lái)確定前面的內(nèi)容的重復(fù)出現(xiàn)的次數(shù):假設(shè)x是一個(gè)數(shù)字,那么{x}表示”前面的字符或字符簇只出現(xiàn)x次”;一個(gè)數(shù)字加逗號(hào),{x,}的意思是”前面的內(nèi)容出現(xiàn)x或更多的次數(shù)”;兩個(gè)用逗號(hào)分隔的數(shù)字,{x,y}表示”前面的內(nèi)容至少出現(xiàn)x次,但不超過(guò)y次”。
字符簇 含義
“^[a-zA-Z_]$” 所有的字母和下劃線
“^[[:alpha:]]{3}$” 所有的3個(gè)字母的單詞
“^a$” 字母a
“^a{4}$” 不是以字母a開頭并且有4個(gè)字母的單詞,比如Aaaa
^a{2,4}$” aa,aaa或aaaa
“^a{1,3}$” a,aa或aaa
“^a{2,}$” 包含多于兩個(gè)a的字符串,比如aaa,aaaa,aaaaa
“^a{2,}” 以兩個(gè)a開頭的單詞,如:aardvark和aaab,但apple不行
“a{2,}” 包含有兩個(gè)a的單詞,如:baad和aaa,但Nantucket不行
“t{2}” 兩個(gè)制表符
“.{2}” 所有的兩個(gè)字符
KK我們可以把模式擴(kuò)展到更多的單詞或數(shù)字:
“^[a-zA-Z0-9_]{1,}$” 所有包含一個(gè)以上的字母、數(shù)字或下劃線的字符串
“^[0-9]{1,}$” 所有的正數(shù)
“^-{0,1}[0-9]{1,}$” 所有的整數(shù)
“^-{0,1}[0-9]{0,}.{0,1}[0-9]{0,}$” 所有的整數(shù)
KK最后一個(gè)例子我們可以這樣考慮:所有以一個(gè)可選的負(fù)號(hào)(-{0,1})開頭(^)、跟著0個(gè)或更多的數(shù)字([0-9]{0,})、和一個(gè)可選的小數(shù)點(diǎn)(.{0,1})再跟上0個(gè)或多個(gè)數(shù)字([0-9]{0,}),并且沒有其他任何東西($)。
KK特殊字符”?”與”{0,1}”是相等的,它們都代表著:”0個(gè)或1個(gè)前面的內(nèi)容”或”前面的內(nèi)容是可選的”。所以:
KKKK”^-{0,1}[0-9]{0,}.{0,1}[0-9]{0,}$”
KK可以簡(jiǎn)化為:
KKKK^-?[0-9]{0,}.?[0-9]{0,}$
KK特殊字符”*”與”{0,}”是相等的,它們都代表著”0個(gè)或多個(gè)前面的內(nèi)容”。字符”+”與{1,}是相等的,表示”1個(gè)或多個(gè)前面的內(nèi)容”,所以上面的4個(gè)例子可以寫成:
“^[a-zA-Z0-9_]+$” 所有包含一個(gè)以上的字母、數(shù)字或下劃線的字符串
“^[0-9]+$” 所有的正數(shù)
“^-?[0-9]+$” 所有的整數(shù)
“^-?[0-9]*.?[0-9]*$” 所有的小數(shù)