-
Notifications
You must be signed in to change notification settings - Fork 157
/
Copy pathpreg-replace.xml
382 lines (374 loc) · 12.9 KB
/
preg-replace.xml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
<?xml version="1.0" encoding="utf-8"?>
<!-- $Revision$ -->
<!-- EN-Revision: d6f54016d62904cfd8200604aadd5e3f0d9bad97 Maintainer: yannick Status: ready -->
<!-- Reviewed: no -->
<refentry xml:id="function.preg-replace" xmlns="http://docbook.org/ns/docbook">
<refnamediv>
<refname>preg_replace</refname>
<refpurpose>Rechercher et remplacer par expression rationnelle standard</refpurpose>
</refnamediv>
<refsect1 role="description">
&reftitle.description;
<methodsynopsis>
<type class="union"><type>string</type><type>array</type><type>null</type></type><methodname>preg_replace</methodname>
<methodparam><type class="union"><type>string</type><type>array</type></type><parameter>pattern</parameter></methodparam>
<methodparam><type class="union"><type>string</type><type>array</type></type><parameter>replacement</parameter></methodparam>
<methodparam><type class="union"><type>string</type><type>array</type></type><parameter>subject</parameter></methodparam>
<methodparam choice="opt"><type>int</type><parameter>limit</parameter><initializer>-1</initializer></methodparam>
<methodparam choice="opt"><type>int</type><parameter role="reference">count</parameter><initializer>&null;</initializer></methodparam>
</methodsynopsis>
<para>
Analyse <parameter>subject</parameter> pour trouver l'expression
rationnelle <parameter>pattern</parameter> et remplace les
résultats par <parameter>replacement</parameter>.
</para>
<para>
Pour faire correspondre une chaîne exacte, plutôt qu'une expression rationnelle,
l'utilisation de <function>str_replace</function> ou <function>str_ireplace</function>
est recommandée à la place de cette fonction.
</para>
</refsect1>
<refsect1 role="parameters">
&reftitle.parameters;
<para>
<variablelist>
<varlistentry>
<term><parameter>pattern</parameter></term>
<listitem>
<para>
Le masque à chercher. Il peut être une chaîne ou un tableau de chaînes.
</para>
<para>
Plusieurs <link linkend="reference.pcre.pattern.modifiers">modificateurs PCRE</link>
sont également disponibles.
</para>
</listitem>
</varlistentry>
<varlistentry>
<term><parameter>replacement</parameter></term>
<listitem>
<para>
La chaîne ou un tableau de chaînes pour le remplacement.
Si ce paramètre est une chaîne et le paramètre <parameter>pattern</parameter>
est un tableau, tous les masques seront remplacés par cette chaîne.
Si les paramètres <parameter>pattern</parameter> et
<parameter>replacement</parameter> sont des tableaux, chaque
<parameter>pattern</parameter> sera remplacé par son
<parameter>replacement</parameter> associé.
Si <parameter>replacement</parameter> à moins d'éléments
que <parameter>pattern</parameter>, alors une chaîne vide est
utilisée pour le reste des valeurs.
</para>
<para>
<parameter>replacement</parameter> peut contenir des références
de la forme <literal>\<replaceable>n</replaceable></literal> ou
<literal>$<replaceable>n</replaceable></literal>.
Cette dernière forme est recommandée. Ces références seront remplacées
par le texte capturé par la <replaceable>n</replaceable>-ième parenthèse
capturante du masque. <replaceable>n</replaceable> peut prendre des
valeurs de 0 à 99, et <literal>\0</literal> ou <literal>$0</literal>,
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é.
</para>
<para>
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
<literal>\1</literal> pour la référence arrière. <literal>\11</literal>, par exemple,
sera confus pour la fonction <function>preg_replace</function> dans le sens où
elle ne saura pas si vous désirez la référence arrière <literal>\1</literal> suivi du nombre
&one; ou si vous désirez la référence arrière <literal>\11</literal>
suivi de "rien". Dans ce cas, la solution est d'utiliser la syntaxe <literal>${1}1</literal>.
Cela créera une référence arrière isolée <literal>$1</literal>, suivi du nombre
littéral &one;.
</para>
<para>
Lorsque vous utilisez l'option obsolète <literal>e</literal>, cette fonction
échappe quelques caractères (<literal>'</literal>, <literal>"</literal>,
<literal>\</literal> 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. <literal>'strlen(\'$1\')+strlen("$2")'</literal>).
Assurez-vous d'être familier avec la <link linkend="language.types.string">syntaxe
des chaînes</link> afin de savoir exactement à quoi la chaîne interprétée doit ressembler.
</para>
</listitem>
</varlistentry>
<varlistentry>
<term><parameter>subject</parameter></term>
<listitem>
<para>
La chaîne ou le tableau contenant des chaînes à chercher et à remplacer.
</para>
<para>
Si <parameter>subject</parameter> est un tableau, alors l'opération
sera appliquée à chacun des éléments du tableau, et le tableau sera retourné.
</para>
<para>
Si le tableau <parameter>subject</parameter> est associatif, alors les clés
seront préservées dans la valeur retournée.
</para>
</listitem>
</varlistentry>
<varlistentry>
<term><parameter>limit</parameter></term>
<listitem>
<para>
Le nombre maximal de remplacement pour chaque masque dans
chaque chaîne <parameter>subject</parameter>. Par défaut, vaut
<literal>-1</literal> (aucune limite).
</para>
</listitem>
</varlistentry>
<varlistentry>
<term><parameter>count</parameter></term>
<listitem>
<para>
Si fournie, cette variable contiendra le nombre de remplacements effectués.
</para>
</listitem>
</varlistentry>
</variablelist>
</para>
</refsect1>
<refsect1 role="returnvalues">
&reftitle.returnvalues;
<para>
<function>preg_replace</function> retourne un tableau si le paramètre
<parameter>subject</parameter> est un tableau, ou une chaîne sinon.
</para>
<para>
Si des correspondances sont trouvées, le nouveau
<parameter>subject</parameter> sera retourné, sinon
<parameter>subject</parameter> sera retourné à l'identique, ou &null;
si une erreur survient.
</para>
</refsect1>
<refsect1 role="errors">
&reftitle.errors;
<para>
Utiliser l'option "\e" est une erreur ; une <constant>E_WARNING</constant>
est émise dans ce cas.
</para>
&pcre.pattern.warning;
</refsect1>
<refsect1 role="examples">
&reftitle.examples;
<para>
<example>
<title>Utilisation des références arrières avec des littéraux numériques</title>
<programlisting role="php">
<![CDATA[
<?php
$string = 'April 15, 2003';
$pattern = '/(\w+) (\d+), (\d+)/i';
$replacement = '${1}1,$3';
echo preg_replace($pattern, $replacement, $string);
?>
]]>
</programlisting>
&example.outputs;
<screen>
<![CDATA[
April1,2003
]]>
</screen>
</example>
</para>
<para>
<example>
<title>Utilisation de tableaux indexé avec <function>preg_replace</function></title>
<programlisting role="php">
<![CDATA[
<?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);
?>
]]>
</programlisting>
&example.outputs;
<screen>
<![CDATA[
Le lent brun grizzly saute par dessus le chien paresseux.
]]>
</screen>
<para>
En triant les masques et les remplacements, vous devriez obtenir le résultat escompté.
</para>
<programlisting role="php">
<![CDATA[
<?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';
ksort($patterns);
ksort($replacements);
echo preg_replace($patterns, $replacements, $string);
?>
]]>
</programlisting>
&example.outputs;
<screen>
<![CDATA[
Le grizzly brun lent saute par dessus le chien paresseux.
]]>
</screen>
</example>
</para>
<para>
<example>
<title>Remplacement de plusieurs valeurs simultanément</title>
<programlisting role="php">
<![CDATA[
<?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');
?>
]]>
</programlisting>
&example.outputs;
<screen>
<![CDATA[
$startDate = 5/27/1999
]]>
</screen>
</example>
</para>
<para>
<example>
<title>Suppression des espaces</title>
<para>
Cet exemple supprime les espaces en trop dans une chaîne.
</para>
<programlisting role="php">
<![CDATA[
<?php
$str = 'foo o';
$str = preg_replace('/\s\s+/', ' ', $str);
// Affichera 'foo o'
echo $str;
?>
]]>
</programlisting>
</example>
</para>
<para>
<example>
<title>Utilisation du paramètre <parameter>count</parameter></title>
<programlisting role="php">
<![CDATA[
<?php
$count = 0;
echo preg_replace(array('/\d/', '/\s/'), '*', 'xp 4 to', -1 , $count);
echo $count; //3
?>
]]>
</programlisting>
&example.outputs;
<screen>
<![CDATA[
xp***to
3
]]>
</screen>
</example>
</para>
</refsect1>
<refsect1 role="notes">
&reftitle.notes;
<note>
<para>
Lorsque vous utilisez des tableaux avec les paramètres
<parameter>pattern</parameter> et
<parameter>replacement</parameter>, les clés sont traitées
dans l'ordre dans lequel elles apparaissent dans le tableau.
Ce <emphasis>n'est pas forcément</emphasis> la même chose que
l'ordre des index numériques. Si vous utilisez des index pour
identifier quel <parameter>pattern</parameter> doit être
remplacé par quel <parameter>replacement</parameter>, il est
recommandé de faire un tri <function>ksort</function> sur chaque
tableau avant de faire appel à <function>preg_replace</function>.
</para>
</note>
<note>
<para>
Quand <parameter>pattern</parameter> et <parameter>replacement</parameter>
sont des tableaux, les règles de correspondance fonctionneront de
manière séquentielle. C'est-à-dire que la deuxième paire
<parameter>pattern</parameter>/<parameter>replacement</parameter>
opérera sur la chaîne de caractères qui résulte de la première paire
<parameter>pattern</parameter>/<parameter>replacement</parameter>,
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é.
</para>
<informalexample>
<programlisting role="php">
<![CDATA[
<?php
$p = array('/a/', '/b/', '/c/');
$r = array('b', 'c', 'd');
print_r(preg_replace($p, $r, 'a'));
// prints d
?>
]]>
</programlisting>
</informalexample>
</note>
</refsect1>
<refsect1 role="seealso">
&reftitle.seealso;
<para>
<simplelist>
<member><link linkend="pcre.pattern">Masques PCRE</link></member>
<member><function>preg_quote</function></member>
<member><function>preg_filter</function></member>
<member><function>preg_match</function></member>
<member><function>preg_replace_callback</function></member>
<member><function>preg_split</function></member>
<member><function>preg_last_error</function></member>
<member><function>str_replace</function></member>
</simplelist>
</para>
</refsect1>
</refentry>
<!-- Keep this comment at the end of the file
Local variables:
mode: sgml
sgml-omittag:t
sgml-shorttag:t
sgml-minimize-attributes:nil
sgml-always-quote-attributes:t
sgml-indent-step:1
sgml-indent-data:t
indent-tabs-mode:nil
sgml-parent-document:nil
sgml-default-dtd-file:"~/.phpdoc/manual.ced"
sgml-exposed-tags:nil
sgml-local-catalogs:nil
sgml-local-ecat-files:nil
End:
vim600: syn=xml fen fdm=syntax fdl=2 si
vim: et tw=78 syn=sgml
vi: ts=1 sw=1
-->