|
(PHP 3 >= 3.0.9, PHP 4, PHP 5)
preg_replace -- Rechercher et remplacer par expression rationnelle standardpreg_replace() analyse subject pour trouver l'expression rationnelle pattern et remplace les résultats par replacement.
replacement peut contenir des références de la forme \\n ou, (depuis PHP 4.0.4) $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.
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 litéral 1.
Si subject est un tableau, alors l'opération sera appliquée à chacun des éléments du tableau, et le tableau sera retourné.
e force preg_replace() à traiter replacement comme du code PHP une fois que les substitutions adéquates ont été faîtes. Conseil : assurez-vous que replacement est un code PHP valide, car sinon, PHP trouvera une erreur d'analyse dans la ligne contenant la fonction preg_replace().
Le masque à chercher. ll peut être soit une chaîne, soit un tableau de chaîne de caractères.
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é son replacement associé. Si replacement à moins d'éléments que pattern, alors une chaîne vide est utilisée pour le reste des valeurs.
La chaîne ou le tableau de chaînes à chercher et à remplacer.
Le nombre maxmal de remplacement pour chaque masque dans chaque chaîne subject. Par défaut, vaut -1 (aucune limite).
Si spécifié, cete 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.
Exemple 3. Utilisation de tableaux indexé avec preg_replace()
L'exemple ci-dessus va afficher :
En triant les masques et les remplacements, vous devriez obtenir le résultat escompté.
L'exemple ci-dessus va afficher :
|
Exemple 4. Remplacement de plusieurs valeurs simultanément
L'exemple ci-dessus va afficher :
|
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 replacé par quel replacement, il est recommandé de faire un tri ksort() sur chaque tableau avant de faire appel à preg_replace().
Précédent | Sommaire | Suivant |
preg_replace_callback | Niveau supérieur | preg_split |
Hosting by: Hurra Communications GmbH
Generated: 2007-01-26 18:02:14