php preg_match,PHP preg_match函数

本文详细介绍了PHP中的preg_match函数,用于进行正则表达式的匹配。preg_match只匹配一次,与preg_match_all的区别在于后者会搜索整个字符串直到结束。文中给出了多个示例,包括大小写不敏感的搜索、单词边界匹配以及从URL中提取域名等应用场景,展示了preg_match在实际编程中的使用技巧。此外,还提到了当只需要检查字符串是否包含另一字符串时,使用strpos或strstr会更为高效。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

preg_match(PHP 3 >= 3.0.9, PHP 4, PHP 5)preg_match — 进行正则表达式匹配。并且只匹配一次,注意与preg_match_all区别。

函数用法

int preg_match_all ( string pattern, string subject, array matches, [int flags] )

返回值

preg_match()返回pattern的匹配次数。 它的值将是0次(不匹配)或1次,因为preg_match()在第一次匹配后 将会停止搜索。preg_match_all()不同于此,它会一直搜索subject直到到达结尾。 如果发生错误preg_match()返回 FALSE。

范例

#1 查找文本字符串”php”

//模式分隔符后的"i"标记这是一个大小写不敏感的搜索

if (preg_match("/php/i", "PHP is the web scripting language of choice.")) {

echo "A match was found.";

} else {

echo "A match was not found.";

}

?>

0

1

2

3

4

5

6

7

//模式分隔符后的"i"标记这是一个大小写不敏感的搜索

if(preg_match("/php/i","PHP is the web scripting language of choice.")){

echo"A match was found.";

}else{

echo"A match was not found.";

}

?>

#2 查找单词”word”

/* 模式中的\b标记一个单词边界,所以只有独立的单词"web"会被匹配,而不会匹配

* 单词的部分内容比如"webbing" 或 "cobweb" */

if (preg_match("/\bweb\b/i", "PHP is the web scripting language of choice.")) {

echo "A match was found.";

} else {

echo "A match was not found.";

}

if (preg_match("/\bweb\b/i", "PHP is the website scripting language of choice.")) {

echo "A match was found.";

} else {

echo "A match was not found.";

}

?>

0

1

2

3

4

5

6

7

8

9

10

11

12

13

14

/* 模式中的\b标记一个单词边界,所以只有独立的单词"web"会被匹配,而不会匹配

* 单词的部分内容比如"webbing" 或 "cobweb" */

if(preg_match("/\bweb\b/i","PHP is the web scripting language of choice.")){

echo"A match was found.";

}else{

echo"A match was not found.";

}

if(preg_match("/\bweb\b/i","PHP is the website scripting language of choice.")){

echo"A match was found.";

}else{

echo"A match was not found.";

}

?>

#3 获取URL中的域名

//从URL中获取主机名称

preg_match('@^(?:http://)?([^/]+)@i',

"http://www.php.net/index.html", $matches);

$host = $matches[1];

//获取主机名称的后面两部分

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

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

?>

0

1

2

3

4

5

6

7

8

9

//从URL中获取主机名称

preg_match('@^(?:http://)?([^/]+)@i',

"http://www.php.net/index.html",$matches);

$host=$matches[1];

//获取主机名称的后面两部分

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

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

?>

以上例程会输出:domain name is: php.net

#4 使用命名子组

$str = 'foobar: 2008';

preg_match('/(?P\w+): (?P\d+)/', $str, $matches);

/* 下面例子在php 5.2.2(pcre 7.0)或更新版本下工作, 然而, 为了后向兼容, 上面的方式是推荐写法. */

// preg_match('/(?\w+): (?\d+)/', $str, $matches);

print_r($matches);

?>

0

1

2

3

4

5

6

7

8

9

10

11

$str='foobar: 2008';

preg_match('/(?P\w+): (?P\d+)/',$str,$matches);

/* 下面例子在php 5.2.2(pcre 7.0)或更新版本下工作, 然而, 为了后向兼容, 上面的方式是推荐写法. */

// preg_match('/(?\w+): (?\d+)/', $str, $matches);

print_r($matches);

?>

以上例程会输出:

Array

(

[0] => foobar: 2008

[name] => foobar

[1] => foobar

[digit] => 2008

[2] => 2008

)

注释

如果你仅仅想要检查一个字符串是否包含另外一个字符串,不要使用preg_match()。 使用strpos()或strstr()替代完成工作会更快。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值