一般都放在 / 之间,定界符。
区分大小写。
行定位符
^ : 开始
$ : 结尾
^abc 以abc开头的可以匹配
abc$ 以abc结尾的可以匹配
单词定界符
\b : 匹配的是完整的单词
\B : 匹配的不能是完整的单词,而是其一部分
\btm\b 匹配 tm
\Btm\B 匹配含有tm的字符串,如htmp,tmp等
字符类
[ ]只能匹配一个字符
选择字符
| 选择前后任意长度字串
T|tm|M 以T开头或t开头后面接m或者M
连字符
[a,b,c,d...A,B,C,D...]等价于[a-zA-Z]
排除字符
[^]不匹配
[^a-zA-Z]匹配不以字母开头的
限定符
?匹配前面的字符0或一次
+ 匹配前面的字符一或多次
* 匹配前面的字符0或多次
{n} 匹配前面的字符n次
{n,} 匹配前面的字符最少n次
{n,m} 匹配前面的字符最少n次,最多m次
点符号
. 匹配除换行符以为的各种一个字符
转义字符
\ 使特殊字符(如, . ? \)变为普通字符。
反斜线
\d 任意一个十进制数字, [0-9]
\D 任意一个非十进制数字
\s 任意一个空白符(空格,换行符,换页符,回车符,水平制表符)
\S 任意一个非空白符
\w 任意一个单词字符,[a-zA-Z0-9]
\W 任意一个非单词字符
括号字符
()改变限定符的作用范围,和分组作用
反向引用
([a-z])([0-9])\1\2
(?P<name>[a-z])(?P<name1>[0-9])(?P=name)(?P=name1)
相关函数
preg_grep(string pattern,array input);
//pattern = '/正则表达式/';
<?php
$ereg = '/\bis\b/';//是is的
$str = 'this is a refister book';
$str = explode(' ', $str);
$arr_st = preg_grep($ereg,$str);
var_dump($arr_st);
?>
int preg_match/preg_match_all(string pattern,string subject [,array matches]);
//返回匹配的次数,如果有matches数组,则匹配结果都存储到matches中。preg_match返回0或1,匹配成功就不继续查找了,而all回一直匹配下去,matches对all是必须的。
string preg_quote(string str [,string delimiter]);
//将str内的特殊字符转义,如果有delimiter,该参数包含的字串也被转义,返回结果字串。
mixed preg_replace(mixed pattern,mixed replacement,mixed subject [,int limit]);
//在subject中匹配pattern,匹配项替换为replacement,limit替换次数。
<?php
$string ='[b]hello[/b]';
$b_str = preg_replace('/\[b\](.*)\[\/b\]/i', '<b>$1</b>',$string);
//$1代表分组(.*) $0代表匹配值
echo $b_str;
?>
mixed preg_replace_callback(mixed pattern,callback callback,mixed subject [,int limit]);
//与replace不同的是用回调函数代替replacement
<?php
function c_back($str){
$str = "<font color=$str[1]>$str[2]</font>";
return $str;
}
$string ='[color=blue]color of font[/color]';
echo preg_replace_callback('/\[color=(.*)\](.*)\[\/color\]/U', "c_back", $string);
?>
array preg_split(string pattern,string subject [,int limit]);
//使用pattern分割字符串,最多limit个元素
更加详细的讲解可以参考
http://www.jb51.net/tools/zhengze.html#negativelookaround