preg_match()
preg_match — 进行正则表达式匹配。 语法:int preg_match ( string $pattern , string $subject [, array $matches [, int $flags ]] ) 在 subject 字符串中搜索与 pattern 给出的正则表达式相匹配的内容。如果提供了 matches ,则其会被搜索的结果所填充。$matches[0] 将包含与整个模式匹配的文本,$matches[1] 将包含与第一个捕获的括号中的子模式所匹配的文本,以此类推。 参数说明: 参数 说明 pattern 正则表达式 subject 需要匹配检索的对象 matches 可选,存储匹配结果的数组, $matches[0] 将包含与整个模式匹配的文本,$matches[1] 将包含与第一个捕获的括号中的子模式所匹配的文本,以此类推 flags 可以是下列标记:PREG_OFFSET_CAPTURE。如果设定本标记,对每个出现的匹配结果也同时返回其附属的字符串偏移量。注意这改变了返回的数组的值,使其中的每个单元也是一个数组,其中第一项为匹配字符串,第二项为其偏移量。本标记自 PHP 4.3.0 起可用。 flags 参数自 PHP 4.3.0 起可用。 preg_match() 返回 pattern 所匹配的次数。要么是 0 次(没有匹配)或 1 次,因为 preg_match() 在第一次匹配之后将停止搜索。preg_match_all() 则相反,会一直搜索到 subject 的结尾处。如果出错 preg_match() 返回 FALSE。 如果只想查看一个字符串是否包含在另一个字符串中,不要用 preg_match()。可以用 strpos() 或 strstr() 替代,要快得多。 获取Google首页title 比如说要获取google首页的title内容,代码如下: 1 <?php 2 $str = file_get_contents('http://www.google.com'); 3 preg_match('/<title>(.*)<\/title>/', $str, $arr); 4 echo $arr[1]; 5 ?> 从网址获取域名 1 <?php 2 preg_match("/^(http:\/\/)?([^\/]+)/i", "http://www.nowamagic.net/index.html", $matches); 3 $host = $matches[2]; // 从主机名中取得后面两段 4 preg_match("/[^\.\/]+\.[^\.\/]+$/", $host, $matches); 5 echo "domain name is: {$matches[0]}\n"; 6 ?> preg_match($pattern,$string,$matcher)其中$pattern对应的就是/^(http:\/\/)?([^\/]+)/i,$string 是http://www.php.net/index.html,$match是匹配到的结果。 如果提供了 matches,则其会被搜索的结果所填充。$matches[0] 将包含与整个模式匹配的文本,$matches[1] 将包含与第一个捕获的括号中的子模式所匹配的文本,以此类推。 $matches[0] 将包含与整个模式匹配的文本。咱们用pring_r打印出来第一个$matches: 1 Array ( 2 [0] => http://www.nowamagic.net 3 [1] => http:// 4 [2] => www.nowamagic.net ) $matches[0] 将包含与整个模式匹配的文本,$matches[1] 将包含与第一个捕获的括号中的子模式所匹配的文本。在正则中,()代表模式:匹配 pattern 并获取这一匹配。所获取的匹配可以从产生的 Matches 集合得到,在VBScript 中使用 SubMatches 集合,在JScript 中则使用 $0…$9 属性。就是说数组中下标为1的值就是正则中/^(http:\/\/)?([^\/]+)/i第一个()里的值!数组下标2的值以此类推。 在文本中搜索特定字符串 view sourceprint? 1 <?php 2 // 模式定界符后面的 "i" 表示不区分大小写字母的搜索 3 if (preg_match ("/nowamagic/i", "Welcome to nowamagic.net.")) { 4 print "A match was found."; 5 } else { 6 print "A match was not found."; 7 } 8 ?>