实现PCRE风格的正则表达式的函数也有7个;但是执行效率和语法支持上PCRE都略优于POSIX函数;
preg_grep()函数:语法格式为:array preg_grep(string pattern,array input);函数功能:使用数组input中的元素一一匹配表达式pattern,最后返回由所有相匹配的元素组成的数组。例如:
<?php
$preg='/\d{3,4}-?\d{7,8}/'; //国内电话格式表达式
$arr = array('043212345678','0431-7654321','12345678'); //数组
$preg_arr = preg_grep($preg,$arr); //使用函数匹配
var_dump($preg_arr); //返回匹配的数组
?>运行结果为:
array (size=2)
0 => string '043212345678' (length=12)
1 => string '0431-7654321' (length=12)
preg_match()函数和preg_match_all函数;格式为:int preg_match/preg_match_all(string pattern,string subject[,array matches]);函数功能:在字符串subject中匹配pattern表达式,函数返回匹配的次数,如果有数组matches,那么每次匹配的结果都将被存储到数组matches中;
注意:preg_match()函数的返回值是0或者1,因为该函数在匹配成功后就停止,参数array matches对该函数是可选参数;而preg_match_all()函数则会一直匹配到最后才停止,参数array matches对于preg_match_all()函数是必须有的;
实例如下:
<?php
$str = 'This is an example!';
$preg = '/\b\w{2}\b/';
$num1 = preg_match($preg,$str,$str1);
echo $num1."<br>";
var_dump($str1);
$num2 = preg_match_all($preg,$str,$str2);
echo '<p>'.$num2.'<br>';
var_dump($str2);
?>运行结果为:1
array (size=1)
0 => string 'is' (length=2)
2
array (size=1)
0 =>
array (size=2)
0 => string 'is' (length=2)
1 => string 'an' (length=2)
preg_quote()函数:格式为:string preg_quote(string str[,string delimiter]);函数功能:将字符串str中的所有特殊字符进行自动转义,如果有string delimiter,那么该参数包含的字串也将被转义;函数返回转以后的字串;例如:
输出常用的特殊字符,并且将字母b也当做特殊字符输出:
<?php
$str ='!、$、^、*、+、.、[、]、\\、/、b、<、>';
$str2= 'b';
$match_one = preg_quote($str,$str2); //将$str和$str2字符进行转义
echo $match_one; //输出转义后的字符
?>运行结果为:\!、\$、\^、\*、\+、\.、\[、\]、\\、/、\b、\<、\>
补充说明:这里的特殊字符是指正则表达式中具有一定意义的元字符,其他如@ #等则不会被当做特殊字符处理;
preg_replace()函数:语法格式为:mixed preg_replace(mixed pattern , mixed replacement,mixed subject[,int limit]);函数功能:在字符串subject中匹配表达式pattern,并将匹配项替换成字串replacement;如果有参数limit,则替换limit次;实例:
<?php
$string ='[b]粗字体[/b]'; //定义一个字串
$b_rst = preg_replace('/\[b\](.*)\[\/b\]/i','<b>$1</b>',$string); //使用函数替换
echo $b_rst;
?>
运行结果为:粗字体
说明:preg_replace()函数中的字串”$1”是在正则表达式外调用分组,按照$1、$2排列,一次表示从左到右分组顺序,也就是括号顺序;
preg_replace_callback()函数:语法格式为: mixed preg_replace_callback(mixed pattern,callback callback,mixed subject[,int limit]);函数的功能:该函数同preg_replace()函数功能相同,都用于查找和替换字串,不同的是该函数使用一个回调函数(callback)来代替replacement参数;
例如:使用回调函数来实现UBB功能:
<?php
function c_back($str){
$str = "<font color=$str[1]>$str[2]</font>";
return $str;
}
$string = '[color=blue]字体颜色[/color]';
echo preg_replace_callback('/\[color=(.*)\](.*)\[\/color\]/U',"c_back",$string);
?>
运行结果为:字体颜色
preg_split()函数:函数格式为:array preg_split(string pattern,string subject[,int limit]);函数功能:使用表达式pattern来分割字符串subject,如果有参数limit,那么数组最多有limit个元素,函数的用法和ereg_split()函数的使用方法相同;
应用正则表达式实现UBB使用帮助:UBB技术是一项比较成熟的技术,用来过滤危险的 html代码,又能让用户使用一些文字、图形效果,如使用[b]将文字加粗,使用[i]将文字变为斜体等,这些技术使用的就是正则表达式中的查找和替换,即将“[···]”格式的表达式转换成”<···>“格式:实例:
<?php
$url = '[url=http://www.baidu.com/]百度[/url]';
echo '<br>链接:'.preg_replace('/\[url=(http:\/\/\w+(\.\w+)+\/.*)\](.*)\[\/url\]/is','<a href=\'$1\'>$3</a>',$url);
?>