background image

strpos() 

 

或 strstr() 替代,要快得多。

上面是手册里对 preg_match()

 

的说明, 我认为这个函数的功用在于他可做来做验证,也

 

就是某字符串是否符合某特定要求。其局限是上面所说的要么匹配 0 次,要么 1 次。并且
返回值是匹配次数。当需要全匹配时可使用 preg_match_all().另外值得一提的是$matches 数

 

组的作用,可做自模 式的返回值,有时很有用。
例:
 <?
if (preg_match ("/(\bweb\b)\s(\d)/i", "PHP is the web 45 scripting web 34 language of choice.",
$match)) {
      print "A match was found."; 
      print_r($match);
} else { 
      print "A match was not found.";
}
?>
<?php
// 

 

从 URL 中取得主机名

preg_match("/^(http:\/\/)?([^\/]+)/i",
"http://www.php.net/index.html", $matches);
$host = $matches[2];
// 从主机名中取得后面两段
preg_match("/[^\.\/]+\.[^\.\/]+$/", $host, $matches);
echo "domain name is: {$matches[0]}\n";
?>

preg_match_all
(PHP 3 >= 3.0.9, PHP 4, PHP 5)
preg_match_all -- 进行全局正则表达式匹配
手册上该函数的解释非常明确,就不多做说明了。
说明
int preg_match_all ( string pattern, string subject, array matches [, int flags] )

 

在 subject 

 

中搜索所有与 pattern 

 

给出的正则表达式匹配的内容并将结果以 flags 指定的顺

 

序放到 matches 中。

 

搜 索到第一个匹配项之后,接下来的搜索从上一个匹配项末尾开始。
flags 

 

可以是下列标记的组合(注意把 PREG_PATTERN_ORDER   

和 PREG_SET_ORDER 

合起来用没有意义):
PREG_PATTERN_ORDER

 

对结果排序使 $matches[0] 为全部模式匹配的数组,$matches[1] 为第一个括号中的子模式
所匹配的字符串组成的数组,以此类推。
<?php 
       preg_match_all   ("|<[^>]+>(.*)</[^>]+>|U",   "<b>example:   </b><div   align=left>this   is   a 
test</div>", 
      $out, PREG_PATTERN_ORDER); 
      print $out[0][0].", ".$out[0][1]."\n";