1、正则表达式中包含三种元素分别为:量词、元字符、修饰符 2、前导字符串:就是符号前面的一个字符或字符串
量词 说明
//量词
//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);
我的博客即将同步至腾讯云+社区,邀请大家一同入驻:https://cloud.tencent.com/developer/support-plan?invite_code=pwb80xxqdjku