PHP函数补完: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内容,代码如下:





<?php

$str = file_get_contents('http://www.google.com');

preg_match('/<title>(.*)<\/title>/', $str, $arr);

echo $arr[1];

?>

从网址获取域名



<?php

preg_match("/^(http:\/\/)?([^\/]+)/i", "http://www.nowamagic.net/index.html", $matches);

$host = $matches[2];    // 从主机名中取得后面两段

preg_match("/[^\.\/]+\.[^\.\/]+$/", $host, $matches);

echo "domain name is: {$matches[0]}\n";

?>

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打印出来第一个$matchesArray (

    [0] => http://www.nowamagic.net

    [1] => http://

    [2] => www.nowamagic.net )

$matches[0] 将包含与整个模式匹配的文本,$matches[1] 将包含与第一个捕获的括号中的子模式所匹配的文本。在正则中,()代表模式:匹配 pattern 并获取这一匹配。所获取的匹配可以从产生的 Matches 集合得到,在VBScript 中使用 SubMatches 集合,在JScript 中则使用 $0…$9 属性。就是说数组中下标为1的值就是正则中/^(http:\/\/)?([^\/]+)/i第一个()里的值!数组下标2的值以此类推。



在文本中搜索特定字符串



view sourceprint?

<?php

// 模式定界符后面的 "i" 表示不区分大小写字母的搜索

if (preg_match ("/nowamagic/i", "Welcome to nowamagic.net.")) {

    print "A match was found.";

} else {

    print "A match was not found.";

}

?>

 

你可能感兴趣的:(match)