
返回 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”

preg_match_all:
执行一个“全局”正则表达式匹配

返回完整匹配次数(可能是0),或者如果发生错误返回FALSE。
下面的代码中$subject和$pattern与上面的都一样,唯一不同的是preg_match换成了preg_match_all。
preg_match_all($pattern, $subject, $matches, PREG_OFFSET_CAPTURE);print_r($matches);返回的次数是2,匹配到了两次,再看看数组$matches中的输入,有两个。比上面的多了一个。


$subject = array("dd133aa2", "kk1ff3");$pattern = "/d+/";$result = preg_replace($pattern, "Z", $subject);print_r($result);


这个函数的行为除了可以指定一个callback替代replacement进行替换 字符串的计算,其他方面等同于 preg_replace(),包括返回的结果。
下面的代码也是替换成大写的“Z”,回调函数中每次$matches中的内容就是代码中注释的部分,第一次是133,第二次是2。
$subject = "dd133aa2";$pattern = "/d+/";$result = preg_replace_callback($pattern, function($matches) {//$matches [0] => 133//$matches [0] => 2return "Z"; }, $subject);print_r($result); preg_grep:
返回使用input中key做索引的数组。
下面的示例代码中,在$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);


返回一个使用 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);

preg_match("/(?:D+|<d+>)*[!?]/", "foobar foobar foobar");$result = preg_last_error();//PREG_BACKTRACK_LIMIT_ERROR 调用回溯限制超出print_r($result);preg_quote:

返回转义后的字符串。
下面的代码中,$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);4、模式修正符

以上就是关于php正则表达式的全部内容介绍,希望对大家的学习有所帮助。