本文目錄一覽:
- 1、PHP正則表達式如何檢測現有的正確郵箱域名後綴?
- 2、PHP正則表達式基本函數
- 3、史上最全的PHP正則表達式
- 4、php中的preg_match()函數
- 5、如何運用PHP函數preg_match_all測試正則表達式效果
PHP正則表達式如何檢測現有的正確郵箱域名後綴?
這個是IT群里的朋友!我不去群里了,在這裡幫你把問題解決了吧!
其實嚴格說來,正則表達式只是一個模型匹配,所以直接使用模型匹配時我們有一個高通原理,也就是說匹配出來的內容是要大於你所需要的內容。就比此題來說,後邊可以匹配任何一個合規則的內容,而不可能精確地直接是你想要的內容——這就是高通,如果非要匹配到你想要的內容,使用正則運算有時是非常不合適的!所以這裡不建議你使用這方式,或者是部分使用這種方式的形式。
高通就是通過你不全是你想要的,但你想要的一定全在裡邊。
那麼,為什麼不考慮使用ajax的方式呢?後台自己設計一會數據庫,@前半段使用正則表這式,扣後半段直接使用數據存儲的內容,這樣可以精確到任何一個你想要的。
因為這裡你想要的與不想要的其實也很模糊,你也不知道ckk這個域名在以後是不會被啟用!那麼你可以使用數據庫方式,由管理員自由添加!不用去修改那將來的表達式的!
但事實上很少人用這種方式——他們都在使用註冊時郵箱認證的方式,也就是說,發到你郵箱里一封信,輔助你完成註冊,這種情況雖然是高通,其他實他只是方便用戶能輸入正確,而不是要的確信數據,任何設計都要記着這句話——任何客戶端的信息都是不可信的!就算用JS完成了正則,那麼如果對方有意屏掉您的JS這十分容易的!所以你的正則根本不是用來驗證,而是方便用戶。
正是這種原因,高通的理由也是其存在的一個原因!就算使用了我說的數據庫,利用ajax來檢查,那麼別人照樣可以讓你的ajax不工作,而且,不是服務器通過了,郵箱就一定有人註冊的!所以從這方面上來講,數據庫的實現意義也不大!
根據js的特點,客戶端的驗證沒有必要太這於麻煩,就算是服務端的驗證,建議你的也只採用這種方式即可。沒有使用數據庫的必要的——這個代價與達到的效果是不成比例的!
說完了,其實等於我也不解決!
PHP正則表達式基本函數
在PHP正則表達式中需要轉義的字符如下
$^*()+={}[]|/: ? “
注意 perl風格中表達式要求以/開始和結尾 如 /food/ 表匹配字符 food
perl修飾符如下
i 完成不區分大小寫的搜索
g 查找所有出現(all occurrences 完成全局搜索)
m 將一個字符串視為多行(m就表示多(multiple)) 默認情況下 ^和$字符匹配字符串中的最開始和最末尾 使用m修飾符將使^和$匹配字符串中每行的開始
s 將一個字符串視為一行 忽略其中的所有換行符;它與m修飾符正好相反
x 忽略php正則表達式中的空白和注釋
U 第一次匹配後停止 默認情況下 將找到最後一個匹配字符結果 利用這個修飾符可以在第一次匹配後停止 進而形式循環匹配
元字符說明
利用Perl正則表達式還可以做另一件有用的事情 這就是使用各種元字符來搜索匹配 元字符(metacharacter)就是一個前面有反斜線的字母字符 表示某種特殊含義 以下是一些有用的元字符
A 只匹配字符串開頭
b 匹配單詞邊界
B 匹配單詞邊界之外的任意字符
d 匹配數字字符 它與[ ]相同
D 匹配非數字字符的php正則
s 匹配空白字符
S 匹配非空白字符的php正則
[] 包圍一個字符類 字符類包括 [ ] [a z] [a zA Z] 等類似
() 包圍一個字符分組或定義一個反引用
$ 匹配行尾
^ 匹配行首
* 匹配前面的子表達式零次或多次 要匹配 * 字符 請使用 *
+ 匹配前面的子表達式一次或多次 要匹配 + 字符 請使用 +
? 匹配前面的子表達式零次或一次 或指明一個非貪婪限定符 ?
匹配除換行之外的任何字符
引出下一個元字符
w 匹配任何只包含下劃線和字母數字字符的字符串 它與 [a zA Z _]相同
W 匹配沒有下劃線和字母數字字符的字符串的php正則
Perl風格函數有
array preg_grep(string pattern array input [ flags])
搜索數組中所有元素 返回由與某個模式匹配的所有元素組成的數組
PHP 增加了一個可選參數 flag 它接受一個值 PREG_GREP_INVERT 傳遞此標誌將得到與該模式不匹配的數據元素
int preg_match(string pattern string string [ array matches [ int flags [ int offset]]])
在字符串中搜索模式 如果存在返回TRUE 否則返回FALSE
可選輸入參數matches可以包含搜索模式中包含的子模式的各個部分 默認返回 匹配的字符串 當有()子包圍時 會在數組後面輸出
int preg_match_all(string pattern string string array pattern_array [ int order])
和函數 preg_match一樣 不過 preg_match 只搜索一次 而 preg_match_all 會執行循環搜索 返回所有匹配的結果
mixed preg_replace(mixed pattern mixed replacement mixed str [ int limit])
用replacement替換pattern的所有出現 並返回修改後的結果
可選 limit 指定應當發生多少次匹配 不設置limit或設置為 將替換所有出現的情況
lishixinzhi/Article/program/PHP/201311/21050
史上最全的PHP正則表達式
一、校驗數字的表達式
1 數字:
^[0-9]*$
2 n位的數字:
^\d{n}$
3 至少n位的數字:
^\d{n,}$
4 m-n位的數字:
^\d{m,n}$
5 零和非零開頭的數字:
^(0|[1-9][0-9]*)$
6 非零開頭的最多帶兩位小數的數字:
^([1-9][0-9]*)+(.[0-9]{1,2})?$
7 帶1-2位小數的正數或負數:
^(\-)?\d+(\.\d{1,2})?$
8 正數、負數、和小數:
^(\-|\+)?\d+(\.\d+)?$
9 有兩位小數的正實數:
^[0-9]+(.[0-9]{2})?$
10 有1~3位小數的正實數:
^[0-9]+(.[0-9]{1,3})?$
11 非零的正整數:
^[1-9]\d*$ 或 ^([1-9][0-9]*){1,3}$ 或 ^\+?[1-9][0-9]*$
12 非零的負整數:
^\-[1-9][]0-9″*$ 或 ^-[1-9]\d*$
13 非負整數:
^\d+$ 或 ^[1-9]\d*|0$
14 非正整數:
^-[1-9]\d*|0$ 或 ^((-\d+)|(0+))$
15 非負浮點數:
^\d+(\.\d+)?$ 或 ^[1-9]\d*\.\d*|0\.\d*[1-9]\d*|0?\.0+|0$
16 非正浮點數:
^((-\d+(\.\d+)?)|(0+(\.0+)?))$ 或 ^(-([1-9]\d*\.\d*|0\.\d*[1-9]\d*))|0?\.0+|0$
17 正浮點數:
^[1-9]\d*\.\d*|0\.\d*[1-9]\d*$ 或 ^(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*))$
18 負浮點數:
^-([1-9]\d*\.\d*|0\.\d*[1-9]\d*)$ 或 ^(-(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*)))$
19 浮點數:
^(-?\d+)(\.\d+)?$ 或 ^-?([1-9]\d*\.\d*|0\.\d*[1-9]\d*|0?\.0+|0)$
二、校驗字符的表達式
1 漢字:
^[\u4e00-\u9fa5]{0,}$
2 英文和數字:
^[A-Za-z0-9]+$ 或 ^[A-Za-z0-9]{4,40}$
3 長度為3-20的所有字符:
^.{3,20}$
4 由26個英文字母組成的字符串:
^[A-Za-z]+$
5 由26個大寫英文字母組成的字符串:
^[A-Z]+$
6 由26個小寫英文字母組成的字符串:
^[a-z]+$
7 由數字和26個英文字母組成的字符串:
^[A-Za-z0-9]+$
8 由數字、26個英文字母或者下劃線組成的字符串:
^\w+$ 或 ^\w{3,20}$
9 中文、英文、數字包括下劃線:
^[\u4E00-\u9FA5A-Za-z0-9_]+$
10 中文、英文、數字但不包括下劃線等符號:
^[\u4E00-\u9FA5A-Za-z0-9]+$ 或 ^[\u4E00-\u9FA5A-Za-z0-9]{2,20}$
11 可以輸入含有^%’,;=?$\”等字符:
[^%’,;=?$\x22]+
12 禁止輸入含有~的字符:
[^~\x22]+
三、特殊需求表達式
1、 Email地址:
^\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$
2 、域名:
[a-zA-Z0-9][-a-zA-Z0-9]{0,62}(/.[a-zA-Z0-9][-a-zA-Z0-9]{0,62})+/.?
3 、InternetURL:
[a-zA-z]+://[^\s]* 或 ^http://([\w-]+\.)+[\w-]+(/[\w-./?%=]*)?$
4 、手機號碼:
^(13[0-9]|14[5|7]|15[0|1|2|3|5|6|7|8|9]|18[0|1|2|3|5|6|7|8|9])\d{8}$
5 、電話號碼(“XXX-XXXXXXX”、”XXXX-XXXXXXXX”、”XXX-XXXXXXX”、”XXX-XXXXXXXX”、”XXXXXXX”和”XXXXXXXX):
^(\(\d{3,4}-)|\d{3.4}-)?\d{7,8}$
6 國內電話號碼(0511-4405222、021-87888822):
\d{3}-\d{8}|\d{4}-\d{7}
7 、身份證號:
15或18位身份證:
^\d{15}|\d{18}$
15位身份證:
^[1-9]\d{7}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{3}$
18位身份證:
^[1-9]\d{5}[1-9]\d{3}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{4}$
8、 短身份證號碼(數字、字母x結尾):
^([0-9]){7,18}(x|X)?$
或
^\d{8,18}|[0-9x]{8,18}|[0-9X]{8,18}?$
9 、帳號是否合法(字母開頭,允許5-16位元組,允許字母數字下劃線):
^[a-zA-Z][a-zA-Z0-9_]{4,15}$
10 、密碼(以字母開頭,長度在6~18之間,只能包含字母、數字和下劃線):
^[a-zA-Z]\w{5,17}$
11 、強密碼(必須包含大小寫字母和數字的組合,不能使用特殊字符,長度在8-10之間):
^(?=.*\d)(?=.*[a-z])(?=.*[A-Z]).{8,10}$
12、 日期格式:
^\d{4}-\d{1,2}-\d{1,2}
13、 一年的12個月(01~09和1~12):
^(0?[1-9]|1[0-2])$
14 、一個月的31天(01~09和1~31):
^((0?[1-9])|((1|2)[0-9])|30|31)$
15 、錢的輸入格式:
16 、1.有四種錢的表示形式我們可以接受:”10000.00″ 和 “10,000.00”, 和沒有 “分” 的 “10000” 和 “10,000”:
^[1-9][0-9]*$
17、 2.這表示任意一個不以0開頭的數字,但是,這也意味着一個字符”0″不通過,所以我們採用下面的形式:
^(0|[1-9][0-9]*)$
18 、3.一個0或者一個不以0開頭的數字.我們還可以允許開頭有一個負號:
^(0|-?[1-9][0-9]*)$
19 、4.這表示一個0或者一個可能為負的開頭不為0的數字.讓用戶以0開頭好了.把負號的也去掉,因為錢總不能是負的吧.下面我們要加的是說明可能的小數部分:
^[0-9]+(.[0-9]+)?$
20 、5.必須說明的是,小數點後面至少應該有1位數,所以”10.”是不通過的,但是 “10” 和 “10.2” 是通過的:
^[0-9]+(.[0-9]{2})?$
21、 6.這樣我們規定小數點後面必須有兩位,如果你認為太苛刻了,可以這樣:
^[0-9]+(.[0-9]{1,2})?$
22、 7.這樣就允許用戶只寫一位小數.下面我們該考慮數字中的逗號了,我們可以這樣:
^[0-9]{1,3}(,[0-9]{3})*(.[0-9]{1,2})?$
23 、8.1到3個數字,後面跟着任意個 逗號+3個數字,逗號成為可選,而不是必須:
^([0-9]+|[0-9]{1,3}(,[0-9]{3})*)(.[0-9]{1,2})?$
24 、備註:這就是最終結果了,別忘了”+”可以用”*”替代如果你覺得空字符串也可以接受的話(奇怪,為什麼?)最後,別忘了在用函數時去掉去掉那個反斜杠,一般的錯誤都在這裡
25 、xml文件:
^([a-zA-Z]+-?)+[a-zA-Z0-9]+\\.[x|X][m|M][l|L]$
26 、中文字符的正則表達式:
[\u4e00-\u9fa5]
27 、雙位元組字符:
[^\x00-\xff]
(包括漢字在內,可以用來計算字符串的長度(一個雙位元組字符長度計2,ASCII字符計1))
28 、空白行的正則表達式:\n\s*\r (可以用來刪除空白行)
29 、HTML標記的正則表達式:
(\S*?)[^]*.*?|.*? / (網上流傳的版本太糟糕,上面這個也僅僅能部分,對於複雜的嵌套標記依舊無能為力)
30 、首尾空白字符的正則表達式:^\s*|\s*$或(^\s*)|(\s*$) (可以用來刪除行首行尾的空白字符(包括空格、製表符、換頁符等等),非常有用的表達式)
31 、騰訊QQ號:[1-9][0-9]{4,} (騰訊QQ號從10000開始)
32 、中國郵政編碼:[1-9]\d{5}(?!\d) (中國郵政編碼為6位數字)
33、 IP地址:\d+\.\d+\.\d+\.\d+ (提取IP地址時有用)
php中的preg_match()函數
preg_match()函數用於正則表達式知識匹配,如果成功則返回1,否則返回0。
Preg_match()在成功匹配之後停止匹配,如果要實現所有結果的內部匹配,則使用preg_match_all()函數。
php函數取得字符串長度:
1.首先,創建一個新的PHP文件並將其命名為test.php。
2.在test.php文件中,定義兩個字符串,一個是純英文字符串,另一個是中英文混合字符串。
3.使用strlen()方法來計算長度,從程序執行結果來看,strlen()方法計算的字符串長度$Str1是正確的,第二個字符串$Str2是錯誤的。
4.創建一個新的utf8_strlen()函數,並將其參數定義為$string,默認為null。
5.在utf8_strlen()函數中,使用preg_match_all()方法通過正則表達式分割字符串,並將其保存在$match變量中。最後,計算從count()方法獲得的數組元素的數量,並返回結果。
6.使用utf8_strlen()分別計算$Str1和$Str2字符串的長度,並使用echo將結果輸出到頁面。
7.在瀏覽器中運行test.php文件並查看程序執行的結果。從這兩個結果可以看出,統計字符串長度已經成功實現。
如何運用PHP函數preg_match_all測試正則表達式效果
php自學網2 /div div id=”biuuu_3″php自學網3 /div’;PHP函數preg_match_all實例要求:分別將每一個DIV元素的ID和內容取出,如biuuu,biuuu_2,biuuu_3,php自學網,php自學網2和php自學網3(一些常用的抓站方法就是這樣匹配的)分析:字符串是一個簡單的HTML元素,每一個DIV元素對應該一個ID和內容,並且是獨立的,首先考慮如何取出一個DIV內的ID值和內容, 如:php自學網,然後匹配其它類似的元素。一個DIV中需要取出兩個值,也就是兩個匹配的表達式,第一個表達式用於匹配ID值(biuuu),第二個表 達式用於匹配ID的內容(php自學網),正則表達式常用的表達式使用小括號,那麼前面的元素將會變成如下形式: div id=”(biuuu)”(php自學網) /div div id=”(表達式1)”(表達式2) /div表達式1:[a-zA-Z0-9_]+ (表示匹配大小寫字母,數字和下劃線)表達式2:[^]+ (表示不匹配和字符)這樣,PHP函數preg_match_all需要匹配的子表達式就實現了,但是還要需要匹配一個的表達式,方法如下:表達式:/ ‘”(表達式1)”‘(表達式2)/注意其中的雙引號”和/需要使用轉義字符轉義,然後把前面兩個表達式放進去,如下:
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hk/n/297211.html