-
Notifications
You must be signed in to change notification settings - Fork 76
/
Copy pathpreg-replace.xml
421 lines (385 loc) · 16.3 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
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
<?xml version="1.0" encoding="utf-8"?>
<!-- EN-Revision: 62126c55f1c6ed444043e7272c4f9e233818a44b Maintainer: sergey Status: ready -->
<!-- Reviewed: no -->
<refentry xml:id="function.preg-replace" xmlns="http://docbook.org/ns/docbook">
<refnamediv>
<refname>preg_replace</refname>
<refpurpose>Выполняет поиск и замену по регулярному выражению</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>
Функция ищет в строке <parameter>subject</parameter> совпадения
с шаблоном <parameter>pattern</parameter> и заменяет совпадения
на значение <parameter>replacement</parameter>.
</para>
<para>
Вместо этой функции обращаются к функциям <function>str_replace</function>
или <function>str_ireplace</function>, когда требуется найти соответствие точной
строке, а не шаблону.
</para>
</refsect1>
<refsect1 role="parameters">
&reftitle.parameters;
<para>
<variablelist>
<varlistentry>
<term><parameter>pattern</parameter></term>
<listitem>
<para>
Искомый шаблон: строка или массив строк.
</para>
<para>
В шаблоне также указывают
<link linkend="reference.pcre.pattern.modifiers">
модификаторы модуля PCRE
</link>.
</para>
</listitem>
</varlistentry>
<varlistentry>
<term><parameter>replacement</parameter></term>
<listitem>
<para>
Строка или массив строк, в которых функция будет искать
и заменять совпадения.
Эта строка заменит каждую подстроку входной строки,
которая совпала с шаблоном, если в этот параметр передали строку,
а в параметр <parameter>pattern</parameter> — массив.
Функция заменит каждую подстроку, которая совпала
c шаблоном в массиве <parameter>pattern</parameter>,
на значение <parameter>replacement</parameter> с тем же
смещением внутреннего указателя массива, что и у шаблона,
если и параметр <parameter>pattern</parameter>,
и параметр <parameter>replacement</parameter> — массивы.
Функция заменит на пустую строку каждую подстроку,
которая совпала с лишним шаблоном в массиве <parameter>pattern</parameter>,
если массив <parameter>replacement</parameter> содержит
меньше элементов, чем массив <parameter>pattern</parameter>.
</para>
<para>
В параметре <parameter>replacement</parameter> разрешается указывать ссылки вида
<literal>\<replaceable>n</replaceable></literal>
или <literal>$<replaceable>n</replaceable></literal>,
причём лучше предпочесть последний вариант. Каждую такую ссылку
функция заменит на подстроку, которую захватил
<replaceable>n</replaceable>-й подшаблон в круглых скобках.
Номер группы <replaceable>n</replaceable> принимает значения от 0
до 99, причём ссылки <literal>\0</literal> или <literal>$0</literal>
соответствует вхождению всего шаблона.
Открывающие подшаблон скобки нумеруются слева направо, начиная с единицы,
и указывают на номер подшаблона захвата.
Обратите внимание, в отдельных ситуациях обратные слеши в строковых (&string;)
литералах требуют экранирования.
</para>
<para>
Когда при работе с шаблоном замены за обратной ссылкой сразу идёт другое число
(то есть буквальное число идёт сразу после подстроки, которая совпала с шаблоном),
для ссылки на подшаблон нельзя использовать знакомую нотацию вида <literal>\1</literal>.
Например, запись <literal>\11</literal> собьёт функцию <function>preg_replace</function>
с толку, поскольку функция не знает, требуется ли выбрать первую обратную ссылку <literal>\1</literal>,
за которой идёт буквальная цифра <literal>1</literal>,
или требуется выбрать одиннадцатую обратную ссылку <literal>\11</literal>,
за которой ничего не идёт.
Решение состоит в том, чтобы использовать конструкцию <literal>${1}1</literal>,
которая создаёт изолированную обратную ссылку <literal>$1</literal>,
а число <literal>1</literal> оставляет литералом.
</para>
<para>
Если в шаблоне указали устаревший модификатор <literal>e</literal>,
функция заэкранирует в строках, которыми замещаются обратные ссылки,
отдельные символы: <literal>'</literal>, <literal>"</literal>, <literal>\</literal> и NULL.
Это сделали, чтобы гарантировать отсутствие синтаксических ошибок
при записи обратных ссылок в одинарных или двойных кавычках:
<literal>'strlen(\'$1\')+strlen("$2")'</literal>.
Знание <link linkend="language.types.string">синтаксиса записи строк</link>
в PHP помогает понять, как интерпретатор будет видеть строку.
</para>
</listitem>
</varlistentry>
<varlistentry>
<term><parameter>subject</parameter></term>
<listitem>
<para>
Строка или массив строк для поиска и замены.
</para>
<para>
Функция найдёт и заменит каждый элемент массива <parameter>subject</parameter>,
а затем вернёт массив,
если в параметр <parameter>subject</parameter> передали массив.
</para>
<para>
Функция сохранит ключи в массиве с результатами,
если в параметр <parameter>subject</parameter> передали ассоциативный массив.
</para>
</listitem>
</varlistentry>
<varlistentry>
<term><parameter>limit</parameter></term>
<listitem>
<para>
Максимальное количество замен каждого шаблона
для каждой строки <parameter>subject</parameter>.
Значение по умолчанию равно <literal>-1</literal> —
не ограничивать количество замен.
</para>
</listitem>
</varlistentry>
<varlistentry>
<term><parameter>count</parameter></term>
<listitem>
<para>
Функция заполнит эту переменную количеством замен, которые она выполнила,
если переменную указали.
</para>
</listitem>
</varlistentry>
</variablelist>
</para>
</refsect1>
<refsect1 role="returnvalues">
&reftitle.returnvalues;
<para>
Функция <function>preg_replace</function> возвращает массив,
если в параметр <parameter>subject</parameter> передали массив,
иначе возвращается строка.
</para>
<para>
Функция возвращает новую версию значения <parameter>subject</parameter>,
если нашла совпадения,
иначе значение <parameter>subject</parameter> возвращается нетронутым.
Функция возвращает &null;, если возникла ошибка.
</para>
</refsect1>
<refsect1 role="errors">
&reftitle.errors;
<para>
Функция выдаёт ошибку уровня <constant>E_WARNING</constant>,
когда в шаблоне указывают модификатор \e.
</para>
&pcre.pattern.warning;
</refsect1>
<refsect1 role="examples">
&reftitle.examples;
<para>
<example>
<title>
Пример обратных ссылок, за которыми следуют числовые литералы
</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>
Пример обработки функцией <function>preg_replace</function> индексных массивов
</title>
<programlisting role="php">
<![CDATA[
<?php
$string = 'The quick brown fox jumps over the lazy dog.';
$patterns = array();
$patterns[0] = '/quick/';
$patterns[1] = '/brown/';
$patterns[2] = '/fox/';
$replacements = array();
$replacements[2] = 'bear';
$replacements[1] = 'black';
$replacements[0] = 'slow';
echo preg_replace($patterns, $replacements, $string);
?>
]]>
</programlisting>
&example.outputs;
<screen>
<![CDATA[
The bear black slow jumps over the lazy dog.
]]>
</screen>
<para>
После сортировки шаблонов и замен по ключам получаем правильный результат:
</para>
<programlisting role="php">
<![CDATA[
<?php
ksort($patterns);
ksort($replacements);
echo preg_replace($patterns, $replacements, $string);
?>
]]>
</programlisting>
&example.outputs;
<screen>
<![CDATA[
The slow black bear jumps over the lazy dog.
]]>
</screen>
</example>
</para>
<para>
<example>
<title>Пример замены ряда значений по набору шаблонов</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>Пример удаления пробелов</title>
<para>
В этом примере функция удаляет из строки лишние пробелы.
</para>
<programlisting role="php">
<![CDATA[
<?php
$str = 'foo o';
$str = preg_replace('/\s\s+/', ' ', $str);
// Теперь строка будет выглядеть вот так: 'foo o'
echo $str;
?>
]]>
</programlisting>
</example>
</para>
<para>
<example>
<title>
Пример с параметром <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>
Функция обрабатывает ключи в том порядке, в котором ключи появляются в массиве,
когда в параметры <parameter>pattern</parameter> и <parameter>replacement</parameter>
передают массивы.
Порядок ключей в этих массивах — <emphasis>не то же</emphasis>,
что порядок числовых индексов.
Если индексы требуются, чтобы определить,
какой шаблон <parameter>pattern</parameter> требуется заменить
какой заменой <parameter>replacement</parameter>,
перед тем как вызывать функцию <function>preg_replace</function>,
на каждом массиве вызывают функцию <function>ksort</function>.
</para>
</note>
<note>
<para>
Функция применяет правила сопоставления последовательно,
если и в параметр <parameter>pattern</parameter>,
и в параметр <parameter>replacement</parameter> передали массив.
То есть, вторая пара <parameter>pattern</parameter>/<parameter>replacement</parameter>
будет работать со строкой, которую функция получила в результате обработки
первой пары <parameter>pattern</parameter>/<parameter>replacement</parameter>,
а не с исходной строкой.
Когда требуется сымитировать параллельные замены, например,
чтобы поменять два значения местами, один шаблон заменяют промежуточным заполнителем,
а затем в следующей паре заменяют этот промежуточный заполнитель нужной заменой.
</para>
<informalexample>
<programlisting role="php">
<![CDATA[
<?php
$p = array('/a/', '/b/', '/c/');
$r = array('b', 'c', 'd');
print_r(preg_replace($p, $r, 'a'));
// Выводит: d
?>
]]>
</programlisting>
</informalexample>
</note>
</refsect1>
<refsect1 role="seealso">
&reftitle.seealso;
<para>
<simplelist>
<member><link linkend="pcre.pattern">Регулярные выражения 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
-->