⑴ 20涓甯哥敤鐨勬e垯琛ㄨ揪寮
[0-9A-Za-z] {6錛20} 鐢6-20浣嶆暟瀛楁垨榪欏瓧姣嶇粍鎴愩傚尮閰嶈岀粨灝句綅緗銆傛e垯琛ㄨ揪寮忥紝鍙堢О瑙勫垯琛ㄨ揪寮忋傦紙鑻辮錛歊egular Expression錛屽湪浠g爜涓甯哥畝鍐欎負regex銆乺egexp鎴朢E錛夛紝璁$畻鏈虹戝︾殑涓涓姒傚康銆
姝e垯琛ㄨ揪寮忥細^(錛燂紒[0-9]+$)(錛燂紒[a-zA-Z]+$)[0-9A-Za-z]{6錛20} 姝e垯琛ㄨ揪寮忥紝鍙堢О瑙勫垯琛ㄨ揪寮忋傦紙鑻辮錛歊egular Expression錛屽湪浠g爜涓甯哥畝鍐欎負regex銆乺egexp鎴朢E錛夛紝璁$畻鏈虹戝︾殑涓涓姒傚康銆
姝e垯鐨勫啓娉曪細[da-zA-Z]+ 鍙浠ュ尮閰 鏁板瓧錛屽ぇ灝忓啓瀛楁瘝 涓鏁版槸鑷沖皯涓涓 鍙﹀栵紝涓嶈佺敤 w+ 鍥犱負w鏄鍖歸厤瀛楁瘝鏁板瓧涓嬪垝綰匡紝澶氫竴涓涓嬪垝綰匡紝涓嶇﹀悎浣犵殑瑕佹眰鐨勩傚叿浣撳畬鏁翠唬鐮侊紝姝ゅ勪笉緇欒創錛屼綘灝辮嚜宸卞啓鍚с
var s = /^[a-z]+[a-za-z0-9_]*$/錛沘lert(s.test(r))錛涜繖涓鍙鑳藉垽鏂鍙鍏佽稿嚭鐜板瓧姣嶆暟瀛椾笅鍒掔嚎錛屽悓鏃朵互灝忓啓瀛楁瘝寮澶達紝浣嗘槸闀垮害娌℃硶鎺у埗銆傜敤姝e垯鏉ュ垽鏂榪欎釜闀垮害搴旇ユ槸涓嶈屼簡銆
1銆佹e垯琛ㄨ揪寮忎竴鑸鐢ㄤ簬澶勭悊鏂囨湰鍐呭癸紝甯哥敤鍛戒護鏈塯rep錛宻ed錛宎wk錛寁im絳 閫氶厤絎︿竴鑸鐢ㄤ簬鍖歸厤鏂囦歡鍚嶏紝甯哥敤鍛戒護鏈塮ind錛宭s錛宑p絳 鍚勭﹀彿鐨勫惈涔変笉灝界浉鍚.浠涔堝湴鏂逛嬌鐢ㄦe垯琛ㄨ揪寮 vim grep sed awk nginx apache mail鍨冨溇閭浠惰繃婊ゃ
2銆佷互涓嬪氨鏄瀵硅秴甯哥敤鐨凱HP姝e垯琛ㄨ揪寮忚繘琛岀殑鏀墮泦鏁寸悊錛屼負浜嗘柟渚垮ぇ瀹舵洿蹇鏇村ソ鐨勬帉鎻php姝e垯琛ㄨ揪寮忋
3銆丗lags 鍐欏湪緇撴潫鐨/涔嬪悗錛屽彲浠ュ獎鍝嶆暣涓姝e垯琛ㄨ揪寮忕殑鍖歸厤琛屼負銆
姝e垯琛ㄨ揪寮忥紝鍙堢О瑙勫垯琛ㄨ揪寮忋傛槸璁$畻鏈虹戝︾殑涓涓姒傚康銆傛e垯琛ㄨ揪寮忛氬父琚鐢ㄦ潵媯緔銆佹浛鎹㈤偅浜涚﹀悎鏌愪釜妯″紡(瑙勫垯)鐨勬枃鏈銆傝稿氱▼搴忚捐¤璦閮芥敮鎸佸埄鐢ㄦe垯琛ㄨ揪寮忚繘琛屽瓧絎︿覆鎿嶄綔銆備緥濡傦紝鍦≒erl涓灝卞唴寤轟簡涓涓鍔熻兘寮哄ぇ鐨勬e垯琛ㄨ揪寮忓紩鎿庛
姝e垯琛ㄨ揪寮(鑻辨枃錛歊egular Expression)錛屽湪璁$畻鏈虹戝︿腑錛屾槸鎸囦竴涓鐢ㄦ潵鎻忚堪鎴栬呭尮閰嶄竴緋誨垪絎﹀悎鏌愪釜鍙ユ硶瑙勫垯鐨勫瓧絎︿覆鐨勫崟涓瀛楃︿覆銆傚湪寰堝氭枃鏈緙栬緫鍣ㄦ垨鍏朵粬宸ュ叿閲岋紝姝e垯琛ㄨ揪寮忛氬父琚鐢ㄦ潵媯緔㈠拰/鎴栨浛鎹㈤偅浜涚﹀悎鏌愪釜妯″紡鐨勬枃鏈鍐呭廣
姝e垯琛ㄨ揪寮忥紝鍙堢О瑙勫垯琛ㄨ揪寮忋傦紙鑻辮錛歊egular Expression錛屽湪浠g爜涓甯哥畝鍐欎負regex銆乺egexp鎴朢E錛夛紝璁$畻鏈虹戝︾殑涓涓姒傚康銆傛e垯琛ㄨ揪寮忛氬父琚鐢ㄦ潵媯緔銆佹浛鎹㈤偅浜涚﹀悎鏌愪釜妯″紡(瑙勫垯)鐨勬枃鏈銆
js甯哥敤姝e垯琛ㄨ揪寮忔暣鏁版垨鑰呭皬鏁幫細^[0-9]+.{0錛1}[0-9]{0錛2}$鍙鑳借緭鍏ユ暟瀛楋細^[0-9]*$銆傚彧鑳借緭鍏n浣嶇殑鏁板瓧錛歗d{n}$銆傚彧鑳借緭鍏ヨ嚦灝憂浣嶇殑鏁板瓧錛歗d{n錛寎$銆傚彧鑳借緭鍏m~n浣嶇殑鏁板瓧錛氥
浠ヤ笅灝辨槸瀵硅秴甯哥敤鐨凱HP姝e垯琛ㄨ揪寮忚繘琛岀殑鏀墮泦鏁寸悊錛屼負浜嗘柟渚垮ぇ瀹舵洿蹇鏇村ソ鐨勬帉鎻php姝e垯琛ㄨ揪寮忋
姝e垯琛ㄨ揪寮忔槸涓縐嶆弿榪板瓧絎︿覆緇撴灉鐨勮娉曡勫垯錛屾槸涓涓鐗瑰畾鐨勬牸寮忓寲妯″紡錛屽彲浠ュ尮閰嶃佹浛鎹銆佹埅鍙栧尮閰嶇殑瀛楃︿覆銆傚父鐢ㄧ殑璇璦鍩烘湰涓婇兘鏈夋e垯琛ㄨ揪寮忥紝濡侸avaScript銆乯ava絳夈
浠ヤ笅灝辨槸瀵硅秴甯哥敤鐨凱HP姝e垯琛ㄨ揪寮忚繘琛岀殑鏀墮泦鏁寸悊錛屼負浜嗘柟渚垮ぇ瀹舵洿蹇鏇村ソ鐨勬帉鎻php姝e垯琛ㄨ揪寮忋
錛歖*$錛乗鏄瀵筽hp涓鍗曞紩鍙風殑杞涔夈傛垨鑰呰繕鏈夋洿綆鍗曠殑 錛乛/錛焄a-z0-9 =錛歖*$錛乮 i琛ㄧず蹇界暐澶у皬鍐欍傛ā寮忓垎闅旂﹀氨鏄涓轟簡鍖哄垎琛ㄨ揪寮忓拰鍍廼榪欐牱鐨勬ā寮忎慨楗扮﹁岃捐$殑銆
浠涔堟槸姝e垯琛ㄨ揪寮忥細綆鍗曠殑璇達紝姝e垯琛ㄨ揪寮忔槸涓縐嶅彲浠ョ敤浜庢ā寮忓尮閰嶅拰鏇挎崲鐨勫己澶у伐鍏楓傚湪鍑犱箮鎵鏈夌殑鍩轟簬UNIX/LINUX緋葷粺鐨勮蔣浠跺伐鍏蜂腑鎵懼埌姝e垯琛ㄨ揪寮忕殑鐥曡抗錛屼緥濡傦細Perl鎴朠HP鑴氭湰璇璦銆
ThinkPHP鐨勮嚜鍔ㄩ獙璇佸父鐢ㄧ殑姝e垯 涓鑸鎴戜滑瑙佺殑姣旇緝澶氱殑鏄璁劇疆瑙勫垯涓簉equire銆乪mail涔嬬被鐨勶紝鍏跺疄榪欎簺鏈韜涔熸槸灞炰簬姝e垯琛ㄨ揪寮忛獙璇佹柟寮忥紝鍙鏄緋葷粺鍐呯疆瀹氫箟浜嗕竴浜涘父鐢ㄧ殑姝e垯琛ㄨ揪寮忚屽凡銆
鍏抽敭鍦版柟鏄奼夊瓧鐨勮〃紺篭xa0-xff銆備笅闈㈡槸鎴戝啓鐨勪緥瀛愮▼搴忥紝璋冭瘯閫氳繃錛氾紵php str=奼夊瓧123456abcdef+-*/ABCDE錛丂#$%^&*()緇撳熬銆
1銆乗w灝辨槸鍖歸厤瀛楁瘝鎴栨暟瀛楁垨涓嬪垝綰挎垨奼夊瓧錛+鍒欎笌*宸涓嶅氾紝鍖哄埆鏄+鍖呮嫭閲嶅0嬈★紝鑰*灝卞彲浠ャ=灝眜shi鍖歸厤=鍙 涓や釜鏂滄潬鍒欒〃紺烘e垯琛ㄨ揪寮忕殑鍒嗙晫銆
2銆佹e垯琛ㄨ揪寮忕殑闄愬畾絎︽湁錛歍hinkPHP鐨勮嚜鍔ㄩ獙璇佹満鍒舵槸涓轟簡榪涜岃〃鍗曟暟鎹楠岃瘉錛岄獙璇佸彲浠ユ敮鎸乫unction銆 callback銆乧onfirm銆乪qual銆乽nique鍜宺egex錛岃繖閲岃佽茬殑鏄浣跨敤姝e垯琛ㄨ揪寮忚繘琛岄獙璇併傜壒孌婂瓧絎 璁稿氬厓瀛楃﹁佹眰鍦ㄨ瘯鍥懼尮閰嶅畠浠鏃剁壒鍒瀵瑰緟銆
3銆乛/錛焄a-zA-Z0-9 =錛歖*$錛乗鏄瀵筽hp涓鍗曞紩鍙風殑杞涔夈傛垨鑰呰繕鏈夋洿綆鍗曠殑 錛乛/錛焄a-z0-9 =錛歖*$錛乮 i琛ㄧず蹇界暐澶у皬鍐欍傛ā寮忓垎闅旂﹀氨鏄涓轟簡鍖哄垎琛ㄨ揪寮忓拰鍍廼榪欐牱鐨勬ā寮忎慨楗扮﹁岃捐$殑銆
⑵ PHP正則表達式的使用技巧
PHP正則表達式的定義
用於描述字元排列和匹配模式的一種語法規則 它主要用於字元串的模式分割 匹配 查找及替換操作
PHP中的正則函數
PHP中有兩套正則函數 兩者功能差不多 分別為
一套是由PCRE(Perl Compatible Regular Expression)庫提供的 使用 preg_ 為前綴命名的函數
一套由POSIX(Portable Operating System Interface of Unix )擴展提供的 使用以 ereg_ 為前綴命名的函數 (POSIX的正則函數庫 自PHP 以後 就不在推薦使用 從PHP 以後 就將被移除)
由於POSIX正則即將推出歷史舞台 並且PCRE和perl的形式差不多 更利於我們在perl和php之間切換 所以這里重點介紹PCRE正則的使用
PCRE正則表達式
PCRE全稱為Perl Compatible Regular Expression 意思是Perl兼容正則表達式
在PCRE中 通常將模式表達式(即正則表達式)包含在兩個反斜線 / 之間 如 /apple/
正則中重要的幾個概念有 元字元 轉義 模式單元(重復) 反義 引用和斷言 這些概念都可以在文章[ ]中輕松的理解和掌握
常用的元字元(Meta character)
元字元 說明
/A 匹配字元串串首的原子
/Z 匹配字元串串尾的原子
/b 匹配單詞的邊界 //bis/ 匹配頭為is的字元串 /is/b/ 匹配尾為is的字元串 //bis/b/ 定界
/B 匹配除單詞邊界之外的任意字元 //Bis/ 匹配單詞 This 中的 is
/d 匹配一個數字 等價於[ ]
/D 匹配除數字以外任何一個字元 等價於[^ ]
/w 匹配一個英文字母 數字或下劃線 等價於[ a zA Z_]
/W 匹配除英文字母 數字和下劃線以外任何一個字元 等價於[^ a zA Z_]
/s 匹配一個空白字元 等價於[/f/t/v]
/S 匹配除空白字元以外任何一個字元 等價於[^/f/t/v]
/f 匹配一個換頁符等價於 /x c 或 /cL
匹配一個換行符 等價於 /x a 或 /cJ
匹配一個回車符等價於/x d 或 /cM
/t 匹配一個製表符 等價於 /x /或/cl
/v 匹配一個垂直製表符 等價於/x b或/ck
/oNN 匹配一個八進制數字
/xNN 匹配一個十六進制數字
/cC 匹配一個控制字元
模式修正符(Pattern Modifiers)
模式修正符在忽略大小寫 匹配多行中使用特別多 掌握了這一個修正符 往往能解決我們遇到的很多問題
i -可同時匹配大小寫字母
M -將字元串視為多行
S -將字元串視為單行 換行符做普通字元看待 使 匹配任何字元
X -模式中的空白忽略不計
U -匹配到最近的字元串
e -將替換的字元串作為表達使用
格式 /apple/i匹配 apple 或 Apple 等 忽略大小寫 /i
PCRE的模式單元
// 提取第一位的屬性
/^/d{ } ([/W])/d{ }// /d{ }$匹配 / / 等字元串 但上述正則表達式不匹配 / 的格式 這是因為模式 [/W] 的結果 / 已經被存儲 下個位置 / 引用時 其匹配模式也是字元 /
當不需要存儲匹配結果時使用非存儲模式單元 (? )
例如/(?:a|b|c)(D|E|F)// g/ 將匹配 aEEg 在一些正則表達式中 使用非存儲模式單元是必要的 否則 需要改變其後引用的順序 上例還可以寫成/(a|b|c)(C|E|F)/ g/
PCRE正則表達式函數
以下為引用的內容
preg_match()和preg_match_all() preg_quote() preg_split() preg_grep() preg_replace()
函數的具體使用 我們可以通過PHP手冊來找到 下面分享一些平時積累的正則表達式
匹配action屬性
以下為引用的內容
$str = ; $match = ; preg_match_all( //s+action=/ (?!)( *?)/ /s/ $str $match); print_r($match);
在正則中使用回調函數
以下為引用的內容
/** * replace some string by callback function * */ function callback_replace() { $url = ; $str = ; $str = preg_replace ( /(?<=/saction=/ )(?!)( *?)(?=/ /s)/e search(/$url // ) $str ); echo $str; } function search($url $match){ return $url / $match; }
帶斷言的正則匹配
以下為引用的內容
$match = ; $str = xxxxxx cn bold font paragraph text
; preg_match_all ( /(?<=<(/w{ })>) *(?=</// >)/ $str $match ); echo 匹配沒有屬性的HTML標簽中的內容 ; print_r ( $match );
替換HTML源碼中的地址
以下為引用的內容
$form_ = preg_replace ( /(?<=/saction=/ |/ssrc=/ |/s)(?!|javascript)( *?)(?=/ /s)/e add_url(/$url / // / ) $form_ );
lishixin/Article/program/PHP/201311/21027
⑶ PHP用正則表達式做注冊頁面
// 定義正則表達式
$username_pattern = "/^[a-zA-Z0-9_-]{3,16}$/"; // 用戶名必須是 3-16 位英文字母、數字、下劃線或短橫線
$password_pattern = "/^[a-zA-Z0-9_-]{6,18}$/"; // 密碼必須是派豎型 6-18 位英文字母、數字、下劃線或短橫線
$email_pattern = "/^([\w\.\-]+)@([\w\-]+)((\.(\w){2,3})+)$/"; // 郵箱必須符合常規格式
// 獲取表單數據
$username = $_POST['username'];
$password = $_POST['password'];
$email = $_POST['email'];
// 驗證用戶名
if (!preg_match($username_pattern, $username)) {
echo "用戶名不合法";
exit;
}
// 驗證密碼塵猜
if (!preg_match($password_pattern, $password)) {
echo "密碼不合法";
exit;
}
// 驗證郵箱
if (!preg_match($email_pattern, $email)) {
echo "郵箱不合法";
exit;
}
// 如果所有表單數據都合法,就將數據纖老插入資料庫或執行其他操作
上述代碼中,使用了 PHP 的 preg_match 函數來進行正則表達式匹配。如果正則表達式匹配成功,函數返回 1,否則返回 0。通過判斷返回值來確定表單數據是否合法。
當然,這只是一個示例,具體的正則表達式和表單驗證邏輯需要根據實際情況進行調整。
⑷ php 正則表達式 只能包含字母和數字
式子:/^[a-zA-Z0-9]+$/u
釋義:
"/":表示正則表達式的定義,固定寫法。
"^":表示開頭。
"[]":表示字元組。匹配所包含的任意一個字元。如,「[ab]」匹配「plain」中的「a」。
"a-z":表示匹配小寫字母a-z的字母範圍。
"A-Z":表示匹配大寫字母A-Z的字母範圍。
"0-9":表示匹配0-9的數字范圍。
"+":表示匹配次數大於等於1。
"$":匹配輸入行尾。如果設置了RegExp對象Multiline屬性,$也匹配「 」或「 」之前的位置。
"u":最後的u是模式修飾符,嚴格的說可能叫預定義常量。表示使用unicode進行匹配。
(4)php正則表達式英文擴展閱讀:
其它正則表達式符號的含義:
1、"*":匹配前面的子表達式任意次。例如,zo*能匹配「z」,也能匹配「zo」以及「zoo」。*等價於{0,}。
2、"?":匹配前面的子表達式零次或一次。例如,「do(es)?」可以匹配「do」或「does」。?等價於{0,1}。
3、"{n}":n是一個非負整數。匹配確定的n次。例如,「o{2}」不能匹配「Bob」中的「o」,但是能匹配「food」中的兩個o。
4、"{n,}":n是一個非負整數。至少匹配n次。例如,「o{2,}」不能匹配「Bob」中的「o」,但能匹配「foooood」中的所有o。「o{1,}」等價於「o+」。「o{0,}」則等價於「o*」。
5、"{n,m}":m和n均為非負整數,其中n<=m。最少匹配n次且最多匹配m次。例如,「o{1,3}」將匹配「fooooood」中的前三個o為一組,後三個o為一組。「o{0,1}」等價於「o?」。請注意在逗號和兩個數之間不能有空格。
⑸ 求PHP 的正則表達式 大全
匹配中文字元的正則表達式: [\u4e00-\u9fa5] 評註:匹配中文還真是個頭疼的事,有了這個表達式就好辦了 匹配雙位元組字元(包括漢字在內):[^\x00-\xff] 評註:可以用來計算字元串的長度(一個雙位元組字元長度計2,ASCII字元計1) 匹配空白行的正則表達式:\n\s*\r 評註:可以用來刪除空白行 匹配HTML標記的正則表達式:<(\S*?)[^>]*>.*?</\1>|<.*? /> 評註:網上流傳的版本太糟糕,上面這個也僅僅能匹配部分,對於復雜的嵌套標記依舊無能為 匹配首尾空白字元的正則表達式:^\s*|\s*$ 評註:可以用來刪除行首行尾的空白字元(包括空格、製表符、換頁符等等),非常有用的表達式 匹配Email地址的正則表達式:\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)* 評註:表單驗證時很實用 匹配網址URL的正則表達式:[a-zA-z]+://[^\s]* 評註:網上流傳的版本功能很有限,上面這個基本可以滿足需求 匹配帳號是否合法(字母開頭,允許5-16位元組,允許字母數字下劃線):^[a-zA-Z][a-zA-Z0-9_]{4,15}$ 評註:表單驗證時很實用 匹配國內電話號碼:\d{3}-\d{8}|\d{4}-\d{7} 評註:匹配形式如 0511-4405222 或 021-87888822 匹配騰訊QQ號:[1-9][0-9]{4,} 評註:騰訊QQ號從10000開始 匹配中國郵政編碼:[1-9]\d{5}(?!\d) 評註:中國郵政編碼為6位數字 匹配身份證:\d{15}|\d{18} 評註:中國的身份證為15位或18位 匹配ip地址:\d+\.\d+\.\d+\.\d+ 評註:提取ip地址時有用 匹配特定數字: ^[1-9]\d*$ //匹配正整數 ^-[1-9]\d*$ //匹配負整數 ^-?[1-9]\d*$ //匹配整數 ^[1-9]\d*|0$ //匹配非負整數(正整數 + 0) ^-[1-9]\d*|0$ //匹配非正整數(負整數 + 0) ^[1-9]\d*\.\d*|0\.\d*[1-9]\d*$ //匹配正浮點數 ^-([1-9]\d*\.\d*|0\.\d*[1-9]\d*)$ //匹配負浮點數 ^-?([1-9]\d*\.\d*|0\.\d*[1-9]\d*|0?\.0+|0)$ //匹配浮點數 ^[1-9]\d*\.\d*|0\.\d*[1-9]\d*|0?\.0+|0$ //匹配非負浮點數(正浮點數 + 0) ^(-([1-9]\d*\.\d*|0\.\d*[1-9]\d*))|0?\.0+|0$ //匹配非正浮點數(負浮點數 + 0) 評註:處理大量數據時有用,具體應用時注意修正 匹配特定字元串: ^[A-Za-z]+$ //匹配由26個英文字母組成的字元串 ^[A-Z]+$ //匹配由26個英文字母的大寫組成的字元串 ^[a-z]+$ //匹配由26個英文字母的小寫組成的字元串 ^[A-Za-z0-9]+$ //匹配由數字和26個英文字母組成的字元串 ^\w+$ //匹配由數字、26個英文字母或者下劃線組成的字元串 /http:\/\/(.*)\//i //匹配外部鏈接地址
滿意請採納
⑹ PHP甯哥敤姝e垯琛ㄨ揪寮忔眹鎬
1銆乗w灝辨槸鍖歸厤瀛楁瘝鎴栨暟瀛楁垨涓嬪垝綰挎垨奼夊瓧錛+鍒欎笌*宸涓嶅氾紝鍖哄埆鏄+鍖呮嫭閲嶅0嬈★紝鑰*灝卞彲浠ャ=灝眜shi鍖歸厤=鍙蜂袱涓鏂滄潬鍒欒〃紺烘e垯琛ㄨ揪寮忕殑鍒嗙晫銆
2銆佹e垯琛ㄨ揪寮忕殑闄愬畾絎︽湁錛歍hinkPHP鐨勮嚜鍔ㄩ獙璇佹満鍒舵槸涓轟簡榪涜岃〃鍗曟暟鎹楠岃瘉錛岄獙璇佸彲浠ユ敮鎸乫unction銆乧allback銆乧onfirm銆乪qual銆乽nique鍜宺egex錛岃繖閲岃佽茬殑鏄浣跨敤姝e垯琛ㄨ揪寮忚繘琛岄獙璇併傜壒孌婂瓧絎﹁稿氬厓瀛楃﹁佹眰鍦ㄨ瘯鍥懼尮閰嶅畠浠鏃剁壒鍒瀵瑰緟銆
3銆乛/錛焄a-zA-Z0-9=錛歖*$錛乗鏄瀵筽hp涓鍗曞紩鍙風殑杞涔夈傛垨鑰呰繕鏈夋洿綆鍗曠殑錛乛/錛焄a-z0-9=錛歖*$錛乮i琛ㄧず蹇界暐澶у皬鍐欍傛ā寮忓垎闅旂﹀氨鏄涓轟簡鍖哄垎琛ㄨ揪寮忓拰鍍廼榪欐牱鐨勬ā寮忎慨楗扮﹁岃捐$殑銆
⑺ php 正則表達式 url匹配
1,preg_grep(pattern,array);它的返回值是一個新數組,新數組的元素是成功匹配的元素。
⑻ 超常用的PHP正則表達式收集整理
以下就是對超常用的PHP正則表達式進行的收集整理,為了方便大家更快更好的掌握php正則表達式。
一、表單驗證匹配
驗證賬號,字母開頭,允許
5-16
位元組,允許字母數字下劃線:^[a-zA-Z][a-zA-Z0-9_]{4,15}$
驗證賬號,不能為空,不能有空格,只能是英文字母:^\S+[a-z
A-Z]$
驗證賬號,不能有空格,不能非數字:^\d+$
驗證用戶密碼,以字母開頭,長度在
6-18
之間:^[a-zA-Z]\w{5,17}$
驗證是否含有
^%&',;=?$\
等字元:[^%&',;=?$\x22]+
匹配Email地址:\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*
匹配騰訊QQ號:[1-9][0-9]{4,}
匹配日期,只能是
2004-10-22
格式:^\d{4}\-\d{1,2}-\d{1,2}$
匹配國內電話號碼:^\d{3}-\d{8}|\d{4}-\d{7,8}$------------評註:匹配形式如010-12345678
或0571-12345678
或
0831-1234567
匹配中國郵政編碼:^[1-9]\d{5}(?!\d)$
匹配身份證:\d{14}(\d{4}|(\d{3}[xX])|\d{1})------------評註:中國的身份證為15
位或18
位
不能為空且二十位元組以上:^[\s|\S]{20,}$
二、字元匹配
匹配由
26
個英文字母組成的字元串:^[A-Za-z]+$
匹配由
26
個大寫英文字母組成的字元串:^[A-Z]+$
匹配由
26
個小寫英文字母組成的字元串:^[a-z]+$
匹配由數字和
26
個英文字母組成的字元串:^[A-Za-z0-9]+$
匹配由數字、26個英文字母或者下劃線組成的字元串:^\w+$
匹配空行:\n[\s|
]*\r
匹配任何內容:[\s\S]*
匹配中文字元:[\x80-\xff]+
或者
[\xa1-\xff]+
只能輸入漢字:^[\x80-\xff],{0,}$
匹配雙位元組字元(包括漢字在內):[^\x00-\xff]
三、匹配數字
只能輸入數字:^[0-9]*$
只能輸入n位的數字:^\d{n}$
只能輸入至少n位數字:^\d{n,}$
只能輸入m-n位的數字:^\d{m,n}$
匹配正整數:^[1-9]\d*$
匹配負整數:^-[1-9]\d*$
匹配整數:^-?[1-9]\d*$
匹配非負整數(正整數
+
0):^[1-9]\d*|0$
匹配非正整數(負整數
+
0):^-[1-9]\d*|0$
匹配正浮點數:^[1-9]\d*\.\d*|0\.\d*[1-9]\d*$
匹配負浮點數:^-([1-9]\d*\.\d*|0\.\d*[1-9]\d*)$
匹配浮點數:^-?([1-9]\d*\.\d*|0\.\d*[1-9]\d*|0?\.0+|0)$
匹配非負浮點數(正浮點數
+
0):^[1-9]\d*\.\d*|0\.\d*[1-9]\d*|0?\.0+|0$
匹配非正浮點數(負浮點數
+
0):^(-([1-9]\d*\.\d*|0\.\d*[1-9]\d*))|0?\.0+|0$
四、其他
匹配HTML標記的正則表達式(無法匹配嵌套標簽):<(\S*?)[^>]*>.*?</\1>|<.*?
/>
匹配網址
URL
:[a-zA-z]+://[^\s]*
匹配
IP
地址:((25[0-5]|2[0-4]\d|[01]?\d\d?)\.){3}(25[0-5]|2[0-4]\d|[01]?\d\d?)
匹配完整域名:[a-zA-Z0-9][-a-zA-Z0-9]{0,62}(\.[a-zA-Z0-9][-a-zA-Z0-9]{0,62})+\.?
提示
上述正則表達式通常都加了
^
與
$
來限定字元的起始和結束,如果需要匹配的內容包括在字元串當中,可能需要考慮去掉
^
和
$
限定符。
以上正則表達式僅供參考,使用時請檢驗後再使用,希望通過這些超常用的PHP正則表達式