天天看點

PHP常用的正規表達式(有些需要調整)

平時做網站經常要用正規表達式,下面是一些講解和例子,僅供大家參考和修改使用:
"^\d+$"  //非負整數(正整數 + 0) 順平注: 驗證輸入id數值,不能為0  $reg1='/^[1-9]\d*$/';
"^[0-9]*[1-9][0-9]*$"  //正整數
"^((-\d+)|(0+))$"  //非正整數(負整數 + 0)
"^-[0-9]*[1-9][0-9]*$"  //負整數
"^-?\d+$"    //整數
"^\d+(\.\d+)?$"  //非負浮點數(正浮點數 + 0)
"^(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*))$"  //正浮點數
"^((-\d+(\.\d+)?)|(0+(\.0+)?))$"  //非正浮點數(負浮點數 + 0)
"^(-(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*)))$"  //負浮點數
"^(-?\d+)(\.\d+)?$"  //浮點數
"^[A-Za-z]+$"  //由26個英文字母組成的字元串
"^[A-Z]+$"  //由26個英文字母的大寫組成的字元串
"^[a-z]+$"  //由26個英文字母的小寫組成的字元串
"^[A-Za-z0-9]+$"  //由數字和26個英文字母組成的字元串
"^\w+$"  //由數字、26個英文字母或者下劃線組成的字元串
"^[\w-]+(\.[\w-]+)*@[\w-]+(\.[\w-]+)+$"    //email位址
"^[a-zA-z]+://(\w+(-\w+)*)(\.(\w+(-\w+)*))*(\?\S*)?$"  //url
/^(d{2}|d{4})-((0([1-9]{1}))|(1[1|2]))-(([0-2]([1-9]{1}))|(3[0|1]))$/   //  年-月-日
/^((0([1-9]{1}))|(1[1|2]))/(([0-2]([1-9]{1}))|(3[0|1]))/(d{2}|d{4})$/   // 月/日/年
"^([w-.]+)@(([[0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3}.)|(([w-]+.)+))([a-zA-Z]{2,4}|[0-9]{1,3})(]?)$"   //Emil
/^((\+?[0-9]{2,4}\-[0-9]{3,4}\-)|([0-9]{3,4}\-))?([0-9]{7,8})(\-[0-9]+)?$/     //電話号碼
"^(d{1,2}|1dd|2[0-4]d|25[0-5]).(d{1,2}|1dd|2[0-4]d|25[0-5]).(d{1,2}|1dd|2[0-4]d|25[0-5]).(d{1,2}|1dd|2[0-4]d|25[0-5])$"   //IP位址
比對中文字元的正規表達式: [\u4e00-\u9fa5]  順平注: 應為 $reg='/[\x{4e00}-\x{9fa5}]/iu';
比對雙位元組字元(包括漢字在内):[^\x00-\xff]
比對空行的正規表達式:\n[\s| ]*\r
比對HTML标記的正規表達式:/<(.*)>.*<\/\1>|<(.*) \/>/
比對首尾空格的正規表達式:(^\s*)|(\s*$)
比對Email位址的正規表達式:\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*
比對網址URL的正規表達式:^[a-zA-z]+://(\\w+(-\\w+)*)(\\.(\\w+(-\\w+)*))*(\\?\\S*)?$
比對帳号是否合法(字母開頭,允許5-16位元組,允許字母數字下劃線):^[a-zA-Z][a-zA-Z0-9_]{4,15}$
比對國内電話号碼:(\d{3}-|\d{4}-)?(\d{8}|\d{7})?
比對騰訊QQ号:^[1-9]*[1-9][0-9]*$
元字元及其在正規表達式上下文中的行為:
\ 将下一個字元标記為一個特殊字元、或一個原義字元、或一個後向引用、或一個八進制轉義符。
^ 比對輸入字元串的開始位置。如果設定了 RegExp 對象的Multiline 屬性,^ 也比對 ’\n’ 或 ’\r’ 之後的位置。
$ 比對輸入字元串的結束位置。如果設定了 RegExp 對象的Multiline 屬性,$ 也比對 ’\n’ 或 ’\r’ 之前的位置。
* 比對前面的子表達式零次或多次。
+ 比對前面的子表達式一次或多次。+ 等價于 {1,}。
? 比對前面的子表達式零次或一次。? 等價于 {0,1}。
{n} n 是一個非負整數,比對确定的n 次。
{n,} n 是一個非負整數,至少比對n 次。
{n,m} m 和 n 均為非負整數,其中n <= m。最少比對 n 次且最多比對 m 次。在逗号和兩個數之間不能有空格。
? 當該字元緊跟在任何一個其他限制符 (*, +, ?, {n}, {n,}, {n,m}) 後面時,比對模式是非貪婪的。非貪婪模式盡可能少的比對所搜尋的字元串,而預設的貪婪模式則盡可能多的比對所搜尋的字元串。
. 比對除 "\n" 之外的任何單個字元。要比對包括 ’\n’ 在内的任何字元,請使用象 ’[.\n]’ 的模式。
(pattern) 比對pattern 并擷取這一比對。
(?:pattern) 比對pattern 但不擷取比對結果,也就是說這是一個非擷取比對,不進行存儲供以後使用。
(?=pattern) 正向預查,在任何比對 pattern 的字元串開始處比對查找字元串。這是一個非擷取比對,也就是說,該比對不需要擷取供以後使用。
(?!pattern) 負向預查,與(?=pattern)作用相反
x|y 比對 x 或 y。
[xyz] 字元集合。
[^xyz] 負值字元集合。
[a-z] 字元範圍,比對指定範圍内的任意字元。
[^a-z] 負值字元範圍,比對任何不在指定範圍内的任意字元。
\b 比對一個單詞邊界,也就是指單詞和空格間的位置。
\B 比對非單詞邊界。
\cx 比對由x指明的控制字元。
\d 比對一個數字字元。等價于 [0-9]。
\D 比對一個非數字字元。等價于 [^0-9]。
\f 比對一個換頁符。等價于 \x0c 和 \cL。
\n 比對一個換行符。等價于 \x0a 和 \cJ。
\r 比對一個回車符。等價于 \x0d 和 \cM。
\s 比對任何空白字元,包括空格、制表符、換頁符等等。等價于[ \f\n\r\t\v]。
\S 比對任何非空白字元。等價于 [^ \f\n\r\t\v]。
\t 比對一個制表符。等價于 \x09 和 \cI。
\v 比對一個垂直制表符。等價于 \x0b 和 \cK。
\w 比對包括下劃線的任何單詞字元。等價于’[A-Za-z0-9_]’。
\W 比對任何非單詞字元。等價于 ’[^A-Za-z0-9_]’。
\xn 比對 n,其中 n 為十六進制轉義值。十六進制轉義值必須為确定的兩個數字長。
\num 比對 num,其中num是一個正整數。對所擷取的比對的引用。
\n 辨別一個八進制轉義值或一個後向引用。如果 \n 之前至少 n 個擷取的子表達式,則 n 為後向引用。否則,如果 n 為八進制數字 (0-7),則 n 為一個八進制轉義值。
\nm 辨別一個八進制轉義值或一個後向引用。如果 \nm 之前至少有is preceded by at least nm 個擷取得子表達式,則 nm 為後向引用。如果 \nm 之前至少有 n 個擷取,則 n 為一個後跟文字 m 的後向引用。如果前面的條件都不滿足,若 n 和 m 均為八進制數字 (0-7),則 \nm 将比對八進制轉義值 nm。
\nml 如果 n 為八進制數字 (0-3),且 m 和 l 均為八進制數字 (0-7),則比對八進制轉義值 nml。
\un 比對 n,其中 n 是一個用四個十六進制數字表示的Unicode字元。
比對中文字元的正規表達式: [u4e00-u9fa5]
比對雙位元組字元(包括漢字在内):[^x00-xff]
比對空行的正規表達式:n[s| ]*r
比對HTML标記的正規表達式:/<(.*)>.*</1>|<(.*) />/
比對首尾空格的正規表達式:(^s*)|(s*$)
比對Email位址的正規表達式:w+([-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*
比對網址URL的正規表達式:http://([w-]+.)+[w-]+(/[w- ./?%&=]*)?
利用正規表達式限制網頁表單裡的文本框輸入内容:
用正規表達式限制隻能輸入中文:onkeyup="value=value.replace(/[^u4E00-u9FA5]/g,'')" onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^u4E00-u9FA5]/g,''))"
用正規表達式限制隻能輸入全角字元: onkeyup="value=value.replace(/[^uFF00-uFFFF]/g,'')" onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^uFF00-uFFFF]/g,''))"
用正規表達式限制隻能輸入數字:onkeyup="value=value.replace(/[^d]/g,'') "onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^d]/g,''))"
用正規表達式限制隻能輸入數字和英文:onkeyup="value=value.replace(/[W]/g,'') "onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^d]/g,''))"
=========常用正則式
比對中文字元的正規表達式: [\u4e00-\u9fa5]
比對雙位元組字元(包括漢字在内):[^\x00-\xff]
比對空行的正規表達式:\n[\s| ]*\r
比對HTML标記的正規表達式:/<(.*)>.*<\/\1>|<(.*) \/>/
比對首尾空格的正規表達式:(^\s*)|(\s*$)
比對IP位址的正規表達式:/(\d+)\.(\d+)\.(\d+)\.(\d+)/g //
比對Email位址的正規表達式:\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*
比對網址URL的正規表達式:http://(/[\w-]+\.)+[\w-]+(/[\w- ./?%&=]*)?
sql語句:^(select|drop|delete|create|update|insert).*$
1、非負整數:^\d+$
2、正整數:^[0-9]*[1-9][0-9]*$
3、非正整數:^((-\d+)|(0+))$
4、負整數:^-[0-9]*[1-9][0-9]*$
5、整數:^-?\d+$
6、非負浮點數:^\d+(\.\d+)?$
7、正浮點數:^((0-9)+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*))$
8、非正浮點數:^((-\d+\.\d+)?)|(0+(\.0+)?))$
9、負浮點數:^(-((正浮點數正則式)))$
10、英文字元串:^[A-Za-z]+$
11、英文大寫串:^[A-Z]+$
12、英文小寫串:^[a-z]+$
13、英文字元數字串:^[A-Za-z0-9]+$
14、英數字加下劃線串:^\w+$
15、E-mail位址:^[\w-]+(\.[\w-]+)*@[\w-]+(\.[\w-]+)+$
16、URL:^[a-zA-Z]+://(\w+(-\w+)*)(\.(\w+(-\w+)*))*(\?\s*)?$
或:^http:\/\/[A-Za-z0-9]+\.[A-Za-z0-9]+[\/=\?%\-&_~`@[\]\':+!]*([^<>\"\"])*$
17、郵政編碼:^[1-9]\d{5}$
18、中文:^[\u0391-\uFFE5]+$
19、電話号碼:^((\(\d{2,3}\))|(\d{3}\-))?(\(0\d{2,3}\)|0\d{2,3}-)?[1-9]\d{6,7}(\-\d{1,4})?$
20、手機号碼:^((\(\d{2,3}\))|(\d{3}\-))?13\d{9}$
21、雙位元組字元(包括漢字在内):^\x00-\xff
22、比對首尾空格:(^\s*)|(\s*$)(像vbscript那樣的trim函數)
23、比對HTML标記:<(.*)>.*<\/\1>|<(.*) \/>
24、比對空行:\n[\s| ]*\r
25、提取資訊中的網絡連結:(h|H)(r|R)(e|E)(f|F) *= *('|")?(\w|\\|\/|\.)+('|"| *|>)?
26、提取資訊中的郵件位址:\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*
27、提取資訊中的圖檔連結:(s|S)(r|R)(c|C) *= *('|")?(\w|\\|\/|\.)+('|"| *|>)?
28、提取資訊中的IP位址:(\d+)\.(\d+)\.(\d+)\.(\d+)
29、提取資訊中的中國手機号碼:(86)*0*13\d{9}
30、提取資訊中的中國固定電話号碼:(\(\d{3,4}\)|\d{3,4}-|\s)?\d{8}
31、提取資訊中的中國電話号碼(包括移動和固定電話):(\(\d{3,4}\)|\d{3,4}-|\s)?\d{7,14}
32、提取資訊中的中國郵政編碼:[1-9]{1}(\d+){5}
33、提取資訊中的浮點數(即小數):(-?\d*)\.?\d+
34、提取資訊中的任何數字 :(-?\d*)(\.\d+)?
35、IP:(\d+)\.(\d+)\.(\d+)\.(\d+)
36、電話區号:/^0\d{2,3}$/
37、騰訊QQ号:^[1-9]*[1-9][0-9]*$
38、帳号(字母開頭,允許5-16位元組,允許字母數字下劃線):^[a-zA-Z][a-zA-Z0-9_]{4,15}$
39、中文、英文、數字及下劃線:^[\u4e00-\u9fa5_a-zA-Z0-9]+$