[b]php正则表达式学习笔记分享:[/b]
[b]1.创建正则表达式[/b]
[b]
$regex = '/\d/i';[/b]
与JavaScript中的第一个方式有点像,只是这里的话是个字符串。
[b]
2.正则表达式中的特殊字符[/b]
特殊字符有:
[b]. \ + * ? [ ^ ] $ ( ) { } = ! < > | : -[/b]
[b]3.正则表达式中的函数[/b]
有8个方法,[b]preg_match与preg_match_all,preg_replace与preg_replace_callback,preg_grep、preg_split、preg_last_error和preg_quote。[/b]
[b]
preg_match:[/b]
执行一个正则表达式匹配
[img]http://files.jb51.net/file_images/article/201511/20151113143315388.png?20151013143324[/img]
返回 pattern 的匹配次数。 它的值将是0次(不匹配)或1次,因为preg_match()在
第一次匹配后,将会停止搜索。
$subject = "dd133aa2";
$pattern = '/\d+/';
preg_match($pattern, $subject, $matches, PREG_OFFSET_CAPTURE);
print_r($matches);
上面的示例代码加了参数“PREG_OFFSET_CAPTURE”,这样的话,在$matches中会多一个偏移数。例如下面的“2”
[img]http://files.jb51.net/file_images/article/201511/20151113143403542.png?20151013143412[/img]
[b]preg_match_all:[/b]
执行一个“全局”正则表达式匹配
[img]http://files.jb51.net/file_images/article/201511/20151113143439556.png?20151013143447[/img]
返回完整匹配次数(可能是0),或者如果发生错误返回FALSE。
下面的代码中$subject和$pattern与上面的都一样,唯一不同的是preg_match换成了preg_match_all。
preg_match_all($pattern, $subject, $matches, PREG_OFFSET_CAPTURE);
print_r($matches);
返回的次数是2,匹配到了两次,再看看数组$matches中的输入,有两个。比上面的多了一个。
[img]http://files.jb51.net/file_images/article/201511/20151113143645760.png?2015101314371[/img]
[b]preg_replace:[/b]
执行一个正则表达式的搜索和替换
[img]http://files.jb51.net/file_images/article/201511/20151113143826579.png?20151013143835[/img]
如果subject是一个数组, preg_replace()返回一个数组, 其他情况下返回一个字符串。
如果匹配被查找到,替换后的subject被返回,其他情况下 返回没有改变的 subject。如果发生错误,返回 NULL。
在代码中$subject是一个数组,里面有两组字符串,接下来是将多个数字替换为大写的“Z”。
$subject = array("dd133aa2", "kk1ff3");
$pattern = '/\d+/';
$result = preg_replace($pattern, 'Z', $subject);
print_r($result);
[img]http://files.jb51.net/file_images/article/201511/20151113144306817.png?20151013144317[/img]
[b]preg_replace_callback:[/b]
执行一个正则表达式搜索并且使用一个“回调”进行替换
[img]http://files.jb51.net/file_images/article/201511/20151113144015507.png?20151013144025[/img]
这个函数的行为除了可以指定一个callback替代replacement进行替换 字符串的计算,其他方面等同于 preg_replace(),包括返回的结果。
下面的代码也是替换成大写的“Z”,回调函数中每次$matches中的内容就是代码中注释的部分,第一次是133,第二次是2。
$subject = "dd133aa2";
$pattern = '/\d+/';
$result = preg_replace_callback($pattern, function($matches) {
//$matches [0] => 133
//$matches [0] => 2
return 'Z';
}, $subject);
print_r($result);
[b]preg_grep:[/b]
返回匹配模式的数组条目
[img]http://files.jb51.net/file_images/article/201511/20151113144120866.png?20151013144128[/img]
返回使用input中key做[b]索引的数组[/b]。
下面的示例代码中,在$subject数组中我加了个“ddsdfd”,里面没有包含数字,在做匹配的时候,就把这个没数字的给过滤掉了。
而$result2打印出来的正好相反,是把过滤的打印出来了,但是key还是为2,并不是0。
$subject = array("dd133aa2", "kk1ff3", "ddsdfd");
$pattern = '/\d+/';
$result = preg_grep($pattern, $subject);
$result2 = preg_grep($pattern, $subject, PREG_GREP_INVERT);
print_r($result);
print_r($result2);
[img]http://files.jb51.net/file_images/article/201511/20151113144224051.png?20151013144232[/img]
[b]preg_split:[/b]
通过一个正则表达式分隔字符串
[img]http://files.jb51.net/file_images/article/201511/20151113144356205.png?2015101314444[/img]
返回一个使用 pattern 边界分隔 subject 后得到 的子串组成的数组。
下面代码中,我将$pattern中的表达式加了括号,为了在$result2中捕获到。
$subject = "dd133aa2cc";
$pattern = '/(\d+)/';
$result = preg_split($pattern, $subject);
$result2 = preg_split($pattern, $subject, null, PREG_SPLIT_DELIM_CAPTURE);
print_r($result);
print_r($result2);
[img]http://files.jb51.net/file_images/article/201511/20151113144433233.png?20151013144442[/img]
[b]preg_last_error:[/b]
返回最后一个PCRE正则执行产生的错误代码
preg_match('/(?:\D+|<\d+>)*[!?]/', 'foobar foobar foobar');
$result = preg_last_error();//PREG_BACKTRACK_LIMIT_ERROR 调用回溯限制超出
print_r($result);
[b]preg_quote:[/b]
转义正则表达式字符
[img]http://files.jb51.net/file_images/article/201511/20151113144511984.png?20151013144520[/img]
返回[b]转义后的字符串[/b]。
下面的代码中,$subject中有两个需要转义的字符,“.”和“?”。
将$result打印出后是“dd\.a\?a2cc”,而在$result2中,多加了个参数“a”,这样的话“a”也会被转义,“dd\.\a\?\a2cc”
$subject = "dd.a?a2cc";
$result = preg_quote($subject);
$result2 = preg_quote($subject, 'a');
print_r($result);
print_r($result2);
[b]4、模式修正符[/b]
[b][img]http://files.jb51.net/file_images/article/201511/20151113144708433.jpg?20151013144717[/img]
[/b]
以上就是关于php正则表达式的全部内容介绍,希望对大家的学习有所帮助。