实现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);
 ?>