Maison  >  Article  >  développement back-end  >  Groupes de capture PHP et groupes de non-capture

Groupes de capture PHP et groupes de non-capture

墨辰丷
墨辰丷original
2018-06-06 11:01:061265parcourir

Cet article présente principalement les informations pertinentes sur la capture et la non-capture des groupes d'expressions régulières PHP. Les amis qui en ont besoin peuvent s'y référer

J'ai rencontré un problème de correspondance régulier aujourd'hui, et du coup j'ai découvert que. il y a une capture. Le concept de groupe est également ignoré dans le manuel. Lorsque je me suis tourné vers Baidu, j'ai accidentellement découvert qu'il existe des utilisations spéciales des groupes de capture réguliers en C# et Java. Lorsque j'ai recherché le mot-clé PHP, il n'y avait rien de pertinent. contenu. Je l'ai essayé moi-même et j'ai découvert qu'en PHP, c'est également réalisable, je vais donc le résumer. Tout en partageant, j'espère également que certains experts et apprenants attentifs pourront trouver les problèmes dans ma compréhension.

Qu'est-ce qu'un groupe de capture

Syntaxe du groupe de capture :

Personnages

Description

Exemple

(motif)

correspond au motif et captures En conséquence, le numéro de groupe est automatiquement défini.

(abc)+d

correspond à abcd ou abcabcd

(?e18fde451f5b63a5a78b44101f261060motif)

ou

( ?'name'pattern)

correspond au modèle et capture le résultat, en définissant name sur le nom du groupe.

num

Backreference au groupe de capture . où num est un entier positif.

(w)(w)21

correspond à abba

kebbcc04cafee2af5afdf2af7b838f796

ou

k'name'

Backreference au groupe de capture nommé. où nom est le nom du groupe de capture.

(?1cd70caa06cc6f4a046ab31342a5e7b4w)abck1cd70caa06cc6f4a046ab31342a5e7b4

correspond à xabcx

我们先看一下PHP的正则匹配函数

int preg_match ( string $pattern , string $subject [, array &$matches [, int $flags = 0 [, int $offset = 0 ]]] )

前面两项是我们常用的,$pattern是正则匹配模式,$string是要匹配的字符串。

array &$match,它是一个数组,&表示匹配出来的结果会被写入$match中。

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

int $offset 用于指定从目标字符串的某个未知开始搜索(单位是字节)。

我们主要看一下$match的值里会有什么:

$mode = '/a=(\d+)b=(\d+)c=(\d+)/';
$str='**a=4b=98c=56**';
$res=preg_match($mode,$str,$match);
var_dump($match);

结果如下:

array (size=4)
  0 => string 'a=4b=98c=56' (length=11)
  1 => string '4' (length=1)
  2 => string '98' (length=2)
  3 => string '56' (length=2)

现在我们知道了什么是捕获组,捕获组是正则表达示中以()括起来的部分,每一对()是一个捕获组。

PHP会为它编号,从1开始。至于为什么会从1开始,那是因为PHP把匹配到的完整字符串编号为0。

如果有多个括号或嵌套括号,按左边括号出现的顺序来进行编号,如图:

按图中的匹配模式匹配时,捕获组的123号分别是红绿蓝。

捕获组的忽略与命名

我们还可以阻止PHP为匹配组的编号:在匹配组中模式前加  ?:

$mode = '/a=(\d+)b=(?:\d+)c=(\d+)/';

这样,匹配结果就会变成:

array (size=3)
 0 => string 'a=4b=98c=56' (length=11)
 1 => string '4' (length=1)
 2 => string '56' (length=2)

当然,我们也可以在括号的内部为它给它独特的名字。

命名子组可以接受(?8a11bc632ea32a57b3e3693c7987c420), (?'name') 以及(?P8a11bc632ea32a57b3e3693c7987c420)语法. 之前版本仅接受(?P8a11bc632ea32a57b3e3693c7987c420)语法.

例如:$mode = '/a=(\d+)b=(?P6fd21b5631009a6df3e3d5bae31abfd3\d+)c=(\d+)/';

使用时结果为:

array (size=5)
 0 => string 'a=4b=98c=56' (length=11)
 1 => string '4' (length=1)
 'sec' => string '98' (length=2)
 2 => string '98' (length=2)
 3 => string '56' (length=2)

在保留索引数组的同时,加上一个关联项,key值为捕获组名。

捕获组的反向引用

我们在用preg_replace()函数进行正则替换时,我们还可以使用 \n 或 $n 来引用第n个捕获组.

$mode = '/a=(\d+)b=(\d+)c=(\d+)/';
$str='**a=4b=98c=56**';
$rp='\1/$2/\3/';
echo preg_replace($mode,$rp,$str);//**4/98/56/**

\1表示捕获组1(4),$2为捕获组2(98),\3为捕获组3(56)。

非捕获组的用法:

非捕获组语法:

字符 

描述

Exemple

(?:motif)

Correspond au modèle, mais ne capture pas le résultat correspondant.

'industr(?:y|ies)

correspond à « industrie » ou « industries ».

(?=motif)

Recherche avant de largeur nulle, pas de capture Résultats correspondants .

'Windows (?=95|98|NT|2000)'

correspond à "Windows" dans "Windows2000"

ne correspond pas" "Windows" dans Windows3.1".

(?!modèle)

Recherche négative de largeur nulle, ne capture pas le résultat de la correspondance .

'Windows (?!95|98|NT|2000)'

correspond à "Windows" dans "Windows3.1"

Aucune correspondance "Windows" dans "Windows2000".

(?<=motif)

Aspect rétrospectif de largeur nulle, les correspondances sont pas capturé.

'2000 (?<=Office|Word|Excel)'

correspond à "2000" dans "Office2000"

ne correspond pas" "2000" dans Windows2000".

(?motif)

零宽度负向回查,不捕获匹配结果。

'2000 (?

匹配 " Windows2000" 中的 "2000"

不匹配 " Office2000" 中的 "2000"。

为什么称为非捕获组呢?那是因为它们有捕获组的特性,在匹配模式的()中,但是匹配时,PHP不会为它们编组,它们只会影响匹配结果,并不作为结果输出。

/d(?=xxx)    匹配"后面是xxx的一个数字"。

注意格式:只能放在匹配模式字符串之后!

例如:

$pattern=&#39;/\d(?=abc)/&#39;;
$str="ab36abc8eg";
$res=preg_match($pattern,$str,$match);
var_dump($match);//6

匹配的6,因为只有它作为一个数字,后面还有abc。

(?<=xxx) /d 匹配"前面是xxx的一个数字"

注意格式:只能放在匹配模式字符串之前!

例如:

$pattern=&#39;/(?<=abc)\d/&#39;;
$str="ab36abc8eg";
$res=preg_match($pattern,$str,$match);
var_dump($match);//8

匹配的8,因为只有它作为一个数字,后面还有abc。

与(?=xxx)  (?<=xxx)相对的是(?!=xxx)  (?

它表示前面/后面不是xxx的字符串,这里就不再举例了。

如果您觉得本博文对您有帮助,您可以推荐或关注我,如果您有什么问题,可以在下方留言讨论,谢谢。

总结:以上就是本篇文的全部内容,希望能对大家的学习有所帮助。

相关推荐:

PHP时间类的运用

PHP五种读取文件内容方法

PHP自定义函数实现字符串加密解密

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn