1、正则表达式中包含三种元素分别为:量词、元字符、修饰符
2、前导字符串:就是符号前面的一个字符或字符串
量词 | 说明 |
---|---|
+ | 匹配任何至少包含一个前导字符串 |
* | 匹配任何包含零个或多个前导字符串 |
? | 匹配任何包含零个或1个前导字符串 |
. | 匹配任意一个字符串 |
{x} | 匹配任何包含x个前导字符串 |
{x,y} | 匹配任何包含 x 到 y 个前导字符串 |
{x,} | 匹配任何包含至少x个前导字符串 |
^ | 匹配字符串的行首 |
$ | 匹配字符串的行尾 |
| | 选择符 匹配字符串的左边或者右边 |
() | 分组,提取 |
验证:
//preg_match()函数匹配成功返回1,失败返回0
echo preg_match('/a+/','abc');//返回1
echo preg_match('/a*/','abc');//返回1
echo preg_match('/a?/','abc');//返回1
echo preg_match('/./','abc');//返回1
echo preg_match('/a{2}/','aabc');//返回1
echo preg_match('/a{2,5}/','aaabc');//返回1
echo preg_match('/a{2,}/','aaaaabc');//返回1
echo preg_match('/^a/','bac');//返回0
echo preg_match('/^a/','abc');//返回1
echo preg_match('/a$/','abc');//返回0
echo preg_match('/a$/','cba');//返回1
echo preg_match('/a|b/','a');//返回1
echo preg_match('/a|b/','b');//返回1
echo preg_match('/(abc)+/','abcd');//返回1
元字符 | 说明 |
---|---|
[a-z] | 匹配任何包含小写字母a-z的字符串 |
[A-Z] | 匹配任何包含大写字母A-Z的字符串 |
[0-9] | 匹配任何包含0-9的字符串 |
[abc] | 匹配任何包含小写字母a,b,c的字符串 |
[^abc] | 匹配任何不包含小写字母a,b,c的字符串 |
[a-zA-Z0-9_] | 匹配任何包含a-zA-Z0-9和下划线的字符串 |
\w | 匹配任何包含a-zA-Z0-9和下划线的字符串 |
\W | 匹配任何不包含a-zA-Z0-9和下划线的字符串 |
\d | 匹配任何包含数字字符 |
\D | 匹配任何非数字字符 |
\s | 匹配任何空白字符 |
\S | 匹配任何非空白字符 |
\b | 匹配是否到达了单词边界 |
\B | 匹配没有到达了单词边界 |
\ | 匹配正则中的特殊字符 |
验证:
echo preg_match('/[a-z]/','abc');//返回1
echo preg_match('/[A-Z]/','ABC');//返回1
echo preg_match('/[0-9]/','123');//返回1
echo preg_match('/[abc]/', 'a');//返回1
echo preg_match('/[^abc]/', 'd');//返回1
echo preg_match('/[^a-zA-Z0-9_]/', 'aD45_');//返回1
echo preg_match('/\w/', 'aD45_');//返回1
echo preg_match('/\W/', 'aD45_');//返回0
echo preg_match('/\d/', '123456');//返回1
echo preg_match('/\D/', '123456');//返回0
echo preg_match('/\d/', '123456');//返回1
echo preg_match('/\s/', ' ');//返回1
echo preg_match('/\S/', ' ');//返回0
//单词尾部边界
echo preg_match('/at\b/', 'cat');//返回1
//头单词部边界
echo preg_match('/\bat/', 'attribute');//返回1
//没有到达边界
echo preg_match('/\Bat/', 'attribute');//返回0
//特殊字符 $ ^ * () + = {} [] | \\ : <>
echo preg_match('/\$/', '$');//返回1
修饰符 | 说明 |
---|---|
i | 完全不区分大小写 |
m | 可以采用多行识别,遇到换行也承认匹配规则 |
x | 忽略掉规则模式中的空白字符 |
A | 强制从头开始匹配 |
U | 禁止贪婪匹配,只跟踪到最近的一个匹配符并结束 |
验证:
//i 不区分大小写
echo preg_match('/abcd/','AbcD');//返回0
echo preg_match('/abcd/i','AbcD');//返回1
//m 多行识别
$str = '1a
1a';
preg_match_all('/^1a/',$str,$arr);
print_r($arr);
//结果为Array ( [0] => Array ( [0] => 1a ) )
//默认从头到尾匹配,所以只匹配到一个
preg_match_all('/^1a/m',$str,$arr);//返回1
print_r($arr);
//结果为Array ( [0] => Array ( [0] => 1a [1] => 1a ) )
//每行都会使用规则,所以匹配的到二个,注意第二行前面不要有空格避免干扰
//x 忽略模式的空格
echo preg_match('/a b/','ab');//返回0
echo preg_match('/a b/x','ab');//返回1
//A 强制开头匹配
echo preg_match('/ab/','catabc');//返回1
echo preg_match('/ab/A','catabc');//返回0
echo preg_match('/ab/A','abcdef');//返回1
//U 禁止贪婪匹配
preg_match_all('/php\w+php/','php123phpphp456php',$arr);
print_r($arr);
//结果为Array ( [0] => Array ( [0] => php123phpphp456php ) )
preg_match_all('/php\w+php/U','php123phpphp456php',$arr);
print_r($arr);
//结果为Array ( [0] => Array ( [0] => php123php [1] => php456php ) )
//禁止贪婪匹配后,会就近匹配
//风格函数
//preg_grep()
$arr = array('php5','php6','php7','css','html');
$out = preg_grep('/php[0-9]/', $arr);
print_r($out);
//结果为Array ( [0] => php5 [1] => php6 [2] => php7 )
//preg_match()
echo preg_match('/php[0-9]/','php5');//返回1
//preg_match_all()
preg_match_all('/php[0-9]/','php5php6php7',$arr);
print_r($arr);
//结果为Array ( [0] => Array ( [0] => php5 [1] => php6 [2] => php7 ) )
//preg_quote()
echo preg_quote(' $ ^ * () + = {} [] | \\ : <>');
//结果为 \$ \^ \* \(\) \+ \= \{\} \[\] \| \\ \: \<\>
//preg_replace()
echo preg_replace('/php/','python', 'php1php2php3');
//结果为 python1python2python3
//preg_split()
$str = preg_split('/a/', 'cbabc');
print_r($str);