preg_match_all()

创建于 2024-12-03 / 22
字体: [默认] [大] [更大]

❮ PHP 正则表达式参考

实例

查找字符串中所有出现的"ain":

<?php
$str = "The rain in SPAIN falls mainly on the plains.";
$pattern = "/ain/i";
if(preg_match_all($pattern, $str, $matches)) {
  print_r($matches);
}
?> 亲自试一试 »

定义和用法

preg_match_all() 函数返回在字符串中找到的模式的匹配数,并用找到的匹配填充变量。


语法

preg_match_all(pattern, input, matches, flags, offset)

参数值

参数 描述
pattern 必需。包含一个正则表达式,指示要搜索的内容
input 必需。将在其中执行搜索的字符串
matches 可选。此参数中使用的变量将填充一个包含所有找到的匹配项的数组
flags 可选。一组更改匹配数组结构的选项。

可以选择以下结构之一:
  • PREG_PATTERN_ORDER - 默认值。 matches 数组中的每个元素都是来自正则表达式中同一分组的匹配数组,索引 0 对应于整个表达式的匹配项,其余索引对应于子模式匹配项。
  • PREG_SET_ORDER - 匹配数组中的每个元素都包含字符串中找到的匹配项之一的所有分组的匹配项。
可以应用以下任意数量的选项:
  • PREG_OFFSET_CAPTURE - 启用此选项后,每个匹配项将是一个数组,而不是一个字符串,其中第一个元素是包含匹配项的子字符串,第二个元素是子字符串的第一个字符在输入。
  • PREG_UNMATCHED_AS_NULL - 启用此选项后,不匹配的子模式将返回为 NULL 而不是空字符串。
offset 可选。默认为 0。指示开始搜索到字符串的深度。 preg_match() 函数不会找到出现在此参数中给定位置之前的匹配项

技术细节

返回值: 如果发生错误,则返回找到的匹配数或 false
PHP 版本: 4+
更新日志: PHP 7.2 - 添加了 PREG_UNMATCHED_AS_NULL 标志

PHP 5.4 - 匹配参数变为可选

PHP 5.3.6 - 当偏移量较长时函数返回 false 比输入的长度

PHP 5.2.2 - 除了之前的 (?P<name>) 之外,命名子模式还可以使用 (?'name') 和 (?<name>) 语法

更多实例

实例

使用 PREG_PATTERN_ORDER 设置 matches 数组的结构。 在此示例中,matches 数组中的每个元素都具有正则表达式分组之一的所有匹配项。

<?php
$str = "abc ABC";
$pattern = "/((a)b)(c)/i";
if(preg_match_all($pattern, $str, $matches, PREG_PATTERN_ORDER)) {
  print_r($matches);
}
?> 亲自试一试 »
❮ PHP 正则表达式参考
0 人点赞过