0x01 preg_grep:返回匹配模式的数组条目,返回一个数组。
array preg_grep ( string $pattern , array $input [, int $flags = 0 ]
<?php
$email = '123456@sina.com';
$mode = "/([\w\.]{2,16})@([a-z0-9]{2,4}).([a-z]{2,4})/";
if (preg_match($mode,$email))
echo "邮箱正确";
else
echo "邮箱不合法";
0x02 用"()"进行分组:
例如:检查邮箱
<?php
$email = '123456@sina.com';
$mode = "/([\w\.]{2,16})@([a-z0-9]{2,4}).([a-z]{2,4})/";
if (preg_match($mode,$email))
echo "邮箱正确";
else
echo "邮箱不合法";
邮箱有较为规范的格式,可以通过这个来检查,但是密码格式不定,从目前所学的知识来看用HTML代码来限制更加方便。
0x03 定界正则preg_quote 转义正则表达式字符
string preg_quote ( string $str [, string $delimiter = NULL ] )
其作用是向参数$str中的每个正则表达式语法中的字符前增加一个反斜线
直接从手册上搬样例了……
<?php
$keywords = '$40 for a g3/400';
$keywords = preg_quote($keywords, '/');
echo $keywords; // 返回 \$40 for a g3\/400
?>
0x04 preg_replace 执行一个正则表达式的搜索和替换
mixed preg_replace ( mixed $pattern , mixed $replacement , mixed $subject [, int $limit = -1 [, int &$count ]] )
简单玩个梗
<?php
$str = 'Who is the best';
$mode = "/^who/i";
echo preg_replace($mode,'php',$str);//php is the best
解贪婪问题
比如要出现以下这个情况,将[b][/b]换成<strong></strong>
<?php
$str = '[b]Who[/b] is the [b]best[/b]';
$mode = "/(\[b\])(.*)(\[\/b\])/";
$replace = '<strong>/2</strong>';//[.*]表示零或多个任意字符。
echo preg_replace($mode,$replace,$str);
在浏览器输出时会出现这种情况
Who[/b] is the [b]best(是加粗字体)。由此可见是第一个[b] 和最后一个[/b]匹配了,而没有遵循就近原则,根据前面的PHP初学笔记-正则表达式2
点击打开链接中的取消贪婪,只要在第三行$mode后面加上U即可。
$mode = "/(\[b\])(.*)(\[\/b\])/U";
解释一下<strong></strong>中间的\2是什么
\2是用()分的组,\1表示第一组,\2表示第二组……而这里的第二组就是(.*)用来替代strong标签中出现的字符。