(PHP 4, PHP 5, PHP 7, PHP 8)
preg_replace — Rechercher et remplacer par expression rationnelle standard
$pattern,$replacement,$subject,$limit = -1,&$count = null
   Analyse subject pour trouver l'expression
   rationnelle pattern et remplace les
   résultats par replacement.
  
patternLe 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.
      
subjectLa 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é.
      
limit
       Le nombre maximal de remplacement pour chaque masque dans
       chaque chaîne subject. Par défaut, vaut
       -1 (aucune limite).
      
countSi fournie, cette variable contiendra le nombre de remplacements effectués.
   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.
  
   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.
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
Note:
Lorsque vous utilisez des tableaux avec les paramètres
patternetreplacement, 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 quelpatterndoit être remplacé par quelreplacement, il est recommandé de faire un tri ksort() sur chaque tableau avant de faire appel à preg_replace().