preg_replace Rechercher et remplacer par expression rationnelle standard &reftitle.description; stringarraynullpreg_replace stringarraypattern stringarrayreplacement stringarraysubject intlimit-1 intcount&null; Analyse subject pour trouver l'expression rationnelle pattern et remplace les résultats par replacement. &reftitle.parameters; 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 &string; litéralles les antislashs doivent peut être être échappé. Si le tableau replacement est associatif, alors les clés seront préservées dans la valeur retournée. 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 &one; 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 &one;. 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é. 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. &reftitle.returnvalues; 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. &reftitle.errors; Utiliser l'option "\e" est une erreur ; une E_WARNING est émise dans ce cas. &pcre.pattern.warning; &reftitle.examples; Utilisation des références arrières avec des littéraux numériques ]]> &example.outputs; Utilisation de tableaux indexé avec <function>preg_replace</function> ]]> &example.outputs; En triant les masques et les remplacements, vous devriez obtenir le résultat escompté. ]]> &example.outputs; Remplacement de plusieurs valeurs simultanément ]]> &example.outputs; Suppression des espaces Cet exemple supprime les espaces en trop dans une chaîne. ]]> Utilisation du paramètre <parameter>count</parameter> ]]> &example.outputs; &reftitle.notes; 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. 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é. ]]> &reftitle.seealso; Masques PCRE preg_quote preg_filter preg_match preg_replace_callback preg_split preg_last_error