perlreref - La référence pour les expressions rationnelles en Perl
Cette page est une référence rapide aux expressions rationnelles de Perl (NdT : on emploie couramment le terme expression régulière car le terme anglais est regular expression qui s'abrège en regexp. Mais ne nous y trompons pas, en français, ce sont bien des expressions rationnelles ; nous utiliserons cependant l'abbréviation regexp). Pour de plus amples informations, voir la page de manuel perlre et la page de manuel perlop, ainsi que la section « VOIR AUSSI » de cette page.
=~ détermine la variable à laquelle s'applique l'expression rationnelle. En cas d'absence, $_ est utilisée.
$var =~ /foo/;
!~ détermine à quelle variable l'expression rationnelle s'applique, et effectue une négation sur le résultat de la reconnaissance ; retourne faux si la reconnaissance réussit, vrai si elle échoue.
$var !~ /foo/;
m/pattern/igmsoxc parcourt une chaîne de caractères à la recherche d'un motif, en appliquant les modificateurs donnés.
i insensible à la casse g global - toutes les occurences m mode multiligne - ^ et $ reconnaissent les débuts/fin de lignes s reconnaît comme une seule ligne - '.' reconnaît \n o compiler le motif une seule fois x lisibilité étendue - permet les commentaires c n'efface pas pos lors de l'échec d'une reconnaissance, lors de l'utilisation de /g
Si le motif est une chaîne vide, la dernière regexp reconnue avec succès sera utilisée. Il est possible d'utiliser d'autres délimiteurs que '/', aussi bien pour cet opérateur que pour les suivants.
qr/pattern/imsox permet de stocker une regexp dans une variable ou de la passer en argument. Les modificateurs sont les mêmes que pour l'opérateur m// et sont stockés avec la regexp.
s/pattern/replacement/igmsoxe remplace le motif 'pattern' par le motif 'replacement'. Les modificateurs sont les mêmes que pour l'opérateur m//, avec un supplément :
e évaluer 'replacement' comme une expression
'e' peut être ajouté plusieurs fois. 'replacement' est interprété comme une chaîne entre double-quotes à moins que le délimiteur soit une simple quote.
?pattern? est équivalent à m/pattern/, mais le motif n'est reconnu qu'une seule fois. Aucun autre délimiteur ne peut être utilisé. Doit être réinitialisé avec L<reset|perlfunc/reset>.
\ Permet d'échapper le caractère suivant . Reconnaît n'importe quel caractère, sauf une fin de ligne (à moins que /s soit utilisé) ^ Reconnaît le début de la chaîne (ou de la ligne, si /m est utilisé) $ Reconnaît la fin de la chaîne (ou de la ligne, si /m est utilisé) * Reconnaît l'élément précédent 0 ou plusieurs fois + Reconnaît l'élément précédent au moins 1 fois ? Reconnaît l'élément précédent 0 ou 1 fois {...} Permet de donner un nombre d'occurences de l'élément précédent [...] Reconnaît n'importe lequel des caractères contenus dans les crochets (...) Permet de faire des groupes pour les stocker dans $1, $2,... (?:...) Permet de faire des groupes sans stockage | Reconnaît soit l'expression précédente, soit l'expression suivant l'opérateur \1, \2 ... Le texte du Nième groupe
Ceux-ci fonctionnent comme des chaînes normales.
\a alarme (bip) \e escape (penser à troff) \f page suivante \n nouvelle ligne \r retour chariot \t tabulation \037 caractère en octal (penser au PDP-11) \x7f caractère en hexadécimal \x{263a} caractère en hexadécimal étendu (Unicode SMILEY) \cx control-x \N{name} caractère nommé
\l convertit en minuscule le caractère suivant \u convertit en majuscule le caractère suivant \L convertit en minuscule jusqu'au prochain \E \U convertit en majuscule jusqu'au prochain \E \Q désactive les méta-caractères de motif jusqu'au prochain \E \E fin de modification de casse
Pour les majuscules, voir « Casse de titre ».
Celui-ci fonctionne différemment des chaînes normales :
\b une assertion, pas le caractère retour en arrière, sauf dans une classe de caractères
[amy] Reconnaît 'a', 'm' ou 'y' [f-j] Le tiret permet la reconnaissance d'un ordre (NdT : les caractères de f à j) [f-j-] Un tiret échappé, au début ou à la fin signifie '-' [^f-j] Le chapeau indique une négation (reconnaît tous les caractères sauf ceux-ci)
Les séquences suivantes fonctionnent avec ou sans classe de caractères. Les six premiers sont conscients des locales, tous sont conscients d'Unicode. Les classes de caractères équivalentes par défaut sont données. Voir la page de manuel perllocale et perlunicode pour plus de détails.
\d Reconnaît un chiffre [0-9] \D Négation de \d [^0-9] \w Reconnaît un caractère de "mot" [a-zA-Z0-9_] (alphanumérique plus "_") \W Négation de \w [^a-zA-Z0-9_] \s Reconnaît un caractère "blanc" [ \t\n\r\f] (espace, tabulation,...) \S Négation de \s [^ \t\n\r\f]
\C Reconnaît un octet (avec Unicode, '.' reconnaît un caractère) \pP Reconnaît la propriété Unicode P \p{...} Reconnaît la propriété Unicode (avec un nom long) \PP Négation de \pP \P{...} Négation de la propriété Unicode (avec un nom long) \X Reconnaît une séquence d'un caractère Unicode étendue, équivalent à (?:\PM\pM*)
Les classes de caractères POSIX et leurs équivalents Unicode et Perl :
alnum IsAlnum Alphanumérique alpha IsAlpha Alphabétique ascii IsASCII Un caractère ASCII blank IsSpace [ \t] Un "blanc" horizontal (extension GNU) cntrl IsCntrl Caractère de contrôle digit IsDigit \d Chiffre graph IsGraph Alphanumérique et ponctuation lower IsLower Caractères bas de casse (conscient de locale et d'Unicode) print IsPrint Alphanumérique, point et espace punct IsPunct Ponctuation space IsSpace [\s\ck] Un "blanc" IsSpacePerl \s Un "blanc" au sens de Perl upper IsUpper Caractères "casse de titre" (conscient de locale et d'Unicode) word IsWord \w Alphanumérique et "_" (extension Perl) xdigit IsXDigit [0-9A-Fa-f] Chiffre hexadécimal
Dans une classe de caractères :
POSIX traditional Unicode [:digit:] \d \p{IsDigit} [:^digit:] \D \P{IsDigit}
Toutes sont des assertions de longueur nulle.
^ Reconnaît le début de la chaîne (ou de la ligne, si /m est utilisé) $ Reconnaît la fin de la chaîne (ou de la ligne, si /m est utilisé) ou avant une nouvelle ligne \b Reconnaît une limite de mot (entre \w et \W) \B Négation de \b (entre \w et \w ou entre \W et \W) \A Reconnaît un début de chaîne (avec ou sans /m) \Z Reconnaît une fin de chaîne (avant d'éventuels débuts de ligne) \z Reconnaît la "vraie" fin de chaîne \G Reconnaît l'endroit où le précédent m//g s'est arrêté
Les quantificateurs sont gourmands par défaut -- ils reconnaissent le plus long motif possible.
Maximum Minimum Signification ------- ------- ------------- {n,m} {n,m}? Reconnaît au moins n fois mais pas plus de m fois {n,} {n,}? Reconnaît au moins n fois {n} {n}? Reconnaît exactement n fois * *? Reconnaît 0 fois ou plus (identique à {0,}) + +? Reconnaît 1 fois ou plus (identique à {1,}) ? ?? Reconnaît 0 fois ou 1 (identique à {0,1})
Il n'existe pas de quantificateur {,n} -- il est interprété comme une chaîne.
(?#text) Un commentaire (?imxs-imsx:...) Activer/Désactiver une option (comme les modificateurs pour m//) (?=...) Assertion de longueur nulle pour tester la présence de quelque chose en avant (?!...) Assertion de longueur nulle pour tester l'absence de quelque chose en avant (?<=...) Assertion de longueur nulle pour tester la présence de quelque chose en arrière (?<!...) Assertion de longueur nulle pour tester l'absence de quelque chose en arrière (?>...) Capturer tout ce qui est possible, sans retours arrière (?{ code }) Code embarqué, la valeur de retour devient $^R (??{ code }) Regexp dynamique, la valeur de retour est une regexp (?(cond)yes|no) (cond) est soit un entier entre parenthèses (qui est (?(cond)yes) vrai si le sous-motif mémorisé correspondant reconnaît quelque chose), soit une assertion de longueur nulle (test en arrière, en avant ou évaluation)
$_ Variable utilisée par défaut par les opérateurs $* Activer la reconnaissance multi-ligne (obsolète, disparaît à partir de 5.9.0)
$& Totalité de la chaîne reconnue $` Tout ce qui précède la chaîne reconnue $' Tout ce qui suit la chaîne reconnue
L'utilisation de ces trois derniers opérateurs va ralentir toutes
les regexps utilisées dans votre programme. Vous pouvez consulter
la page de manuel perlvar (@LAST_MATCH_START
) pour trouver des expressions
équivalentes ne ralentissant pas le programme. Voir aussi
la page de manuel Devel::SawAmpersand.
$1, $2 ... contiennent la Xième expression capturée $+ La dernière expression reconnue entre parenthèses $^N Contient la plus récente des captures fermées $^R Contient le résultat de la dernière expression (?{...}) @- Contient les décalages de début de groupes. $-[0] contient le décalage depuis le début de toute la reconnaissance @+ Contient les décalages de fin de groupes. $+[0] contient le décalage de la fin de toute la reconnaissance
Les groupes capturés sont numérotés selon l'ordre de leur parenthèse ouvrante.
lc Mettre une chaîne en bas de casse lcfirst Mettre le premier caractère de la chaîne en bas de casse uc Mettre une chaîne en casse de titre ucfirst Mettre le premier caractère de la chaîne en casse de titre
pos Renvoie ou fixe la position courante de la reconnaissance quotemeta Citer des méta-caractères reset Effacer le statut de ?pattern? study Analyser une chaîne pour optimiser la reconnaissance
split Utiliser une regexp pour diviser une chaîne en plusieurs morceaux
Les quatre premières fonctions correspondent aux séquences
d'échappement \L
, \l
, \U
et \u
. Pour la casse de titre,
cf. « Casse de titre ».
C'est un concept Unicode qui est généralement équivalent au haut de casse, excepté pour certains caractères comme le ``Estset'' allemand.
Iain Truskett.
Ce document peut être ditribué dans les mêmes conditions que Perl lui-même.
David P.C. Wollmann, Richard Soderberg, Sean M. Burke, Tom Christiansen, Jim Cromie et Jeffrey Goff pour leurs précieux conseils.
Cette traduction française correspond à la version anglaise distribuée avec perl 5.8.8. Pour en savoir plus concernant ces traductions, consultez http://perl.enstimac.fr/.
Traduction depuis 5.8.8 par Thomas van Oudenhove.
Aucune pour l'instant.