php 执行正则表达式,执行匹配正则表达式 - PHP 7 中文文档

(PHP 4, PHP 5, PHP 7)

preg_match – 执行匹配正则表达式

说明

preg_match

( string $pattern

, string $subject

[, array &$matches

[, int $flags = 0

[, int $offset = 0

]]] ) : int

搜索subject与pattern给定的正则表达式的一个匹配.

参数

pattern

要搜索的模式,字符串类型。

subject

输入字符串。

matches

如果提供了参数matches,它将被填充为搜索结果。

$matches[0]将包含完整模式匹配到的文本, $matches[1]

将包含第一个捕获子组匹配到的文本,以此类推。

flags

flags可以被设置为以下标记值:

PREG_OFFSET_CAPTURE

如果传递了这个标记,对于每一个出现的匹配返回时会附加字符串偏移量(相对于目标字符串的)。

注意:这会改变填充到matches参数的数组,使其每个元素成为一个由

第0个元素是匹配到的字符串,第1个元素是该匹配字符串

在目标字符串subject中的偏移量。

preg_match('/(foo)(bar)(baz)/', 'foobarbaz', $matches, PREG_OFFSET_CAPTURE);

print_r($matches);

?>

以上例程会输出:

Array

(

[0] => Array

(

[0] => foobarbaz

[1] => 0

)

[1] => Array

(

[0] => foo

[1] => 0

)

[2] => Array

(

[0] => bar

[1] => 3

)

[3] => Array

(

[0] => baz

[1] => 6

)

)

offset

通常,搜索从目标字符串的开始位置开始。可选参数 offset 用于

指定从目标字符串的某个位置开始搜索(单位是字节)。

Note:

使用offset参数不同于向preg_match()

传递按照位置通过substr($subject, $offset)截取目标字符串结果,

因为pattern可以包含断言比如^, $

或者(?<=x)。 比较:

$subject = "abcdef";

$pattern = '/^def/';

preg_match($pattern, $subject, $matches, PREG_OFFSET_CAPTURE, 3);

print_r($matches);

?>

以上例程会输出:

Array

(

)

当这个示例使用截取后传递时

$subject = "abcdef";

$pattern = '/^def/';

preg_match($pattern, substr($subject,3), $matches, PREG_OFFSET_CAPTURE);

print_r($matches);

?>

将会产生匹配

Array

(

[0] => Array

(

[0] => def

[1] => 0

)

)

返回值

preg_match()返回 pattern 的匹配次数。

它的值将是0次(不匹配)或1次,因为preg_match()在第一次匹配后

将会停止搜索。[preg_match_all()](php7/function.preg-match-all)不同于此,它会一直搜索subject

直到到达结尾。

如果发生错误preg_match()返回 FALSE。

更新日志

版本

说明

5.3.6

如果 offset 比 subject 的长度还要大则返回 FALSE。

5.2.2

命名子组可以接受(?), (?'name')

以及(?P)语法。之前版本仅接受(?P)语法。

范例

Example #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.";

}

?>

Example #2 查找单词"word"

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

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

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

echo "A match was found.";

} else {

echo "A match was not found.";

}

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

echo "A match was found.";

} else {

echo "A match was not found.";

}

?>

Example #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";

?>

以上例程会输出:

domain name is: php.net

Example #4 使用命名子组

$str = 'foobar: 2008';

preg_match('/(?Pw+): (?Pd+)/', $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

)

注释

Tip

如果你仅仅想要检查某个字符串是否包含另外一个字符串,不要使用preg_match()。

使用 [strpos()](php7/function.strpos) 会更快。

参见

[PCRE 模式](php7/pcre.pattern)

[preg_quote()](php7/function.preg-quote) – 转义正则表达式字符

[preg_match_all()](php7/function.preg-match-all) – 执行一个全局正则表达式匹配

[preg_replace()](php7/function.preg-replace) – 执行一个正则表达式的搜索和替换

[preg_split()](php7/function.preg-split) – 通过一个正则表达式分隔字符串

[preg_last_error()](php7/function.preg-last-error) – 返回最后一个PCRE正则执行产生的错误代码

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值