一、 概述 1. 正則表達式的測試地址: http://tool.chinaz.com/regex/ 二、具體的常用正則表達式 1. 郵箱正則表達式: 1)\w[-\w.+]*@([A-Za-z0-9][-A-Za-z0-9]+\.)+[A-Za-z]{2,14} 2)\w+([-+.]\w+)*@ ...
一、 概述
1. 正則表達式的測試地址: http://tool.chinaz.com/regex/
二、具體的常用正則表達式
1. 郵箱正則表達式:
1)\w[-\w.+]*@([A-Za-z0-9][-A-Za-z0-9]+\.)+[A-Za-z]{2,14}
2)\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*
3)解析:
-- "\" 叫"跳脫字元"。用於轉義一些特殊符號,如".","/"
-- "\w" 等價於 [a-zA-Z0-9_] 。也匹配漢字
-- "+" 1到多次還可以寫成{1,}
-- 小括弧 來指定子表達式(也叫做分組),然後你就可以指定這個子表達式的重覆次數了, ([-+.]\w+)*
-- [-+.] 方括弧擴起來的部分就是字元域
-- . 匹配除換行符以外的任意字元
4)代碼示例
<?php $email = '[email protected]'; $preg = '/\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*/'; $res = preg_match($preg, $email, $preg_res); var_dump(111,$res,$preg_res);exit;
-- preg_match() : http://php.net/manual/zh/function.preg-match.php
2. 網址表達式:
1) [a-zA-z]+://[^\s]+
2)解析:
-- ^
> 放在字元域(如:[^\w])中表示否定(不包括的意思)——“反向選擇”
> 放在表達式之前,表示以當前這個字元開始。(/^n/i,表示以n開頭)。
-- \s 匹配任意的空白符
三、 附錄
1. 常用元字元
代碼 說明
. 匹配除換行符以外的任意字元
\w 匹配字母或數字或下劃線
\s 匹配任意的空白符
\d 匹配數字
\b 匹配單詞的開始或結束
^ 匹配字元串的開始
$ 匹配字元串的結束
2.常用限定符
代碼/語法 說明
* 重覆零次或更多次
+ 重覆一次或更多次
? 重覆零次或一次
{n} 重覆n次
{n,} 重覆n次或更多次
{n,m} 重覆n到m次
3.常用反義詞
代碼/語法 說明
\W 匹配任意不是字母,數字,下劃線,漢字的字元
\S 匹配任意不是空白符的字元
\D 匹配任意非數字的字元
\B 匹配不是單詞開頭或結束的位置
[^x] 匹配除了x以外的任意字元
[^aeiou] 匹配除了aeiou這幾個字母以外的任意字元