(PHP 4, PHP 5, PHP 7, PHP 8)
preg_replace — Rechercher et remplacer par expression rationnelle standard
Description
preg_replace(
string|array
$pattern,
string|array
$replacement,
string|array
$subject,
int
$limit = -1,
int
&$count =
null): string|array|null
Pour faire correspondre une chaîne exacte, plutôt qu'une expression rationnelle,
l'utilisation de str_replace() ou str_ireplace()
est recommandée à la place de cette fonction.
Liste de paramètres
-
pattern
-
Le masque à chercher. Il peut être une chaîne ou un tableau de chaînes.
Plusieurs modificateurs PCRE
sont également disponibles.
-
replacement
-
La chaîne ou un tableau de chaînes pour le remplacement.
Si ce paramètre est une chaîne et le paramètre pattern
est un tableau, tous les masques seront remplacés par cette chaîne.
Si les paramètres pattern et
replacement sont des tableaux, chaque
pattern sera remplacé par son
replacement associé.
Si replacement à moins d'éléments
que pattern, alors une chaîne vide est
utilisée pour le reste des valeurs.
replacement peut contenir des références
de la forme \n ou
$n.
Cette dernière forme est recommandée. Ces références seront remplacées
par le texte capturé par la n-ième parenthèse
capturante du masque. n peut prendre des
valeurs de 0 à 99, et \0 ou $0,
correspondent au texte de qui satisfait le masque complet. Les parenthèses
ouvrantes sont comptées de gauche à droite (en commençant à 1) pour
déterminer le numéro de parenthèse capturante.
Il est à noter que dans les chaîne de caractères litéralles les antislashs doivent
peut être être échappé.
Lorsque vous travaillez avec un masque de remplacement où une référence arrière
est directement suivie par un nombre (i.e.: placer un nombre littéral immédiatement
après une référence arrière), vous ne pouvez pas utiliser la syntaxe classique
\1 pour la référence arrière. \11, par exemple,
sera confus pour la fonction preg_replace() dans le sens où
elle ne saura pas si vous désirez la référence arrière \1 suivi du nombre
1 ou si vous désirez la référence arrière \11
suivi de "rien". Dans ce cas, la solution est d'utiliser la syntaxe ${1}1.
Cela créera une référence arrière isolée $1, suivi du nombre
littéral 1.
Lorsque vous utilisez l'option obsolète e, cette fonction
échappe quelques caractères (', ",
\ et NULL) dans la chaîne qui remplace les références arrières.
Ce comportement se justifie afin d'assurer qu'aucune erreur de syntaxe
ne survient lors de l'utilisation des références arrières avec des guillemets
simples et doubles (e.g. 'strlen(\'$1\')+strlen("$2")').
Assurez-vous d'être familier avec la syntaxe
des chaînes afin de savoir exactement à quoi la chaîne interprétée doit ressembler.
-
subject
-
La chaîne ou le tableau contenant des chaînes à chercher et à remplacer.
Si subject est un tableau, alors l'opération
sera appliquée à chacun des éléments du tableau, et le tableau sera retourné.
Si le tableau subject est associatif, alors les clés
seront préservées dans la valeur retournée.
-
limit
-
Le nombre maximal de remplacement pour chaque masque dans
chaque chaîne subject. Par défaut, vaut
-1 (aucune limite).
-
count
-
Si fournie, cette variable contiendra le nombre de remplacements effectués.
Valeurs de retour
preg_replace() retourne un tableau si le paramètre
subject est un tableau, ou une chaîne sinon.
Si des correspondances sont trouvées, le nouveau
subject sera retourné, sinon
subject sera retourné à l'identique, ou null
si une erreur survient.
Erreurs / Exceptions
Utiliser l'option "\e" est une erreur ; une E_WARNING
est émise dans ce cas.
Si le masque regex passé ne compile pas à une regex valide, une E_WARNING est émise.
Exemples
Exemple #1 Utilisation des références arrières avec des littéraux numériques
<?php
$string = 'April 15, 2003';
$pattern = '/(\w+) (\d+), (\d+)/i';
$replacement = '${1}1,$3';
echo preg_replace($pattern, $replacement, $string);
?>
L'exemple ci-dessus va afficher :
April1,2003
Exemple #2 Utilisation de tableaux indexé avec preg_replace()
<?php
$string = 'Le renard marron agile saute par dessus le chien paresseux.';
$patterns = array();
$patterns[0] = '/agile/';
$patterns[1] = '/marron/';
$patterns[2] = '/renard/';
$replacements = array();
$replacements[2] = 'grizzly';
$replacements[1] = 'brun';
$replacements[0] = 'lent';
echo preg_replace($patterns, $replacements, $string);
?>
L'exemple ci-dessus va afficher :
Le lent brun grizzly saute par dessus le chien paresseux.
En triant les masques et les remplacements, vous devriez obtenir le résultat escompté.
<?php
ksort($patterns);
ksort($replacements);
echo preg_replace($patterns, $replacements, $string);
?>
L'exemple ci-dessus va afficher :
Le grizzly brun lent saute par dessus le chien paresseux.
Exemple #3 Remplacement de plusieurs valeurs simultanément
<?php
$patterns = array ('/(19|20)(\d{2})-(\d{1,2})-(\d{1,2})/',
'/^\s*{(\w+)}\s*=/');
$replace = array ('\3/\4/\1\2', '$\1 =');
echo preg_replace($patterns, $replace, '{startDate} = 1999-5-27');
?>
L'exemple ci-dessus va afficher :
$startDate = 5/27/1999
Exemple #4 Suppression des espaces
Cet exemple supprime les espaces en trop dans une chaîne.
<?php
$str = 'foo o';
$str = preg_replace('/\s\s+/', ' ', $str);
// Affichera 'foo o'
echo $str;
?>
Exemple #5 Utilisation du paramètre count
<?php
$count = 0;
echo preg_replace(array('/\d/', '/\s/'), '*', 'xp 4 to', -1 , $count);
echo $count; //3
?>
L'exemple ci-dessus va afficher :
xp***to
3
Notes
Note:
Lorsque vous utilisez des tableaux avec les paramètres
pattern et
replacement, les clés sont traitées
dans l'ordre dans lequel elles apparaissent dans le tableau.
Ce n'est pas forcément la même chose que
l'ordre des index numériques. Si vous utilisez des index pour
identifier quel pattern doit être
remplacé par quel replacement, il est
recommandé de faire un tri ksort() sur chaque
tableau avant de faire appel à preg_replace().
Note:
Quand pattern et replacement
sont des tableaux, les règles de correspondance fonctionneront de
manière séquentielle. C'est-à-dire que la deuxième paire
pattern/replacement
opérera sur la chaîne de caractères qui résulte de la première paire
pattern/replacement,
et non sur la chaîne originale. Si vous voulez simuler des remplacements
fonctionnant en parallèle, comme l'échange de deux valeurs, remplacez un
motif par un substitut intermédiaire, puis dans une paire ultérieure,
remplacez ce placeholder intermédiaire par le remplacement souhaité.
<?php
$p = array('/a/', '/b/', '/c/');
$r = array('b', 'c', 'd');
print_r(preg_replace($p, $r, 'a'));
// prints d
?>
Voir aussi
- Masques PCRE
- preg_quote() - Protection des caractères spéciaux des expressions régulières
- preg_filter() - Recherche et remplace avec une expression rationnelle
- preg_match() - Effectue une recherche de correspondance avec une expression rationnelle standard
- preg_replace_callback() - Rechercher et remplacer par expression rationnelle standard en utilisant une fonction de callback
- preg_split() - Éclate une chaîne par expression rationnelle
- preg_last_error() - Retourne le code erreur de la dernière expression PCRE exécutée
- str_replace() - Remplace toutes les occurrences dans une chaîne