array ( 0 => 'index.php', 1 => 'PHP Manual', ), 'head' => array ( 0 => 'UTF-8', 1 => 'es', ), 'this' => array ( 0 => 'function.preg-filter.php', 1 => 'preg_filter', ), 'up' => array ( 0 => 'ref.pcre.php', 1 => 'Funciones de PCRE', ), 'prev' => array ( 0 => 'ref.pcre.php', 1 => 'Funciones de PCRE', ), 'next' => array ( 0 => 'function.preg-grep.php', 1 => 'preg_grep', ), 'alternatives' => array ( ), 'source' => array ( 'lang' => 'es', 'path' => 'reference/pcre/functions/preg-filter.xml', ), ); $setup["toc"] = $TOC; $setup["toc_deprecated"] = $TOC_DEPRECATED; $setup["parents"] = $PARENTS; manual_setup($setup); ?>
(PHP 5 >= 5.3.0, PHP 7, PHP 8)
preg_filter — Realiza una búsqueda y sustitución de una expresión regular
$pattern
,$replacement
,$subject
,$limit
= -1,&$count
= ?preg_filter() es idéntica a preg_replace() excepto que sólo devuelve los sujetos (posiblemente tranformados) donde hubo una coincidencia. Los detalles de cómo trabaja esta función se encuentra en la documentación de preg_replace().
Devuelve un array si el parámetro subject
es un array, de lo contrario devuelve un string.
Si no se encontraron coincidencias u ocurrió un error, se devuelve un array
vacío cuando subject
es un array
o null
de otro modo.
Ejemplo #1 Ejemplo comparando preg_filter() con preg_replace()
<?php
$sujeto = array('1', 'a', '2', 'b', '3', 'A', 'B', '4');
$patrón = array('/\d/', '/[a-z]/', '/[1a]/');
$sustitución = array('A:$0', 'B:$0', 'C:$0');
echo "preg_filter devuelve\n";
print_r(preg_filter($patrón, $sustitución, $sujeto));
echo "preg_replace devuelve\n";
print_r(preg_replace($patrón, $sustitución, $sujeto));
?>
El resultado del ejemplo sería:
preg_filter devuelve Array ( [0] => A:C:1 [1] => B:C:a [2] => A:2 [3] => B:b [4] => A:3 [7] => A:4 ) preg_replace devuelve Array ( [0] => A:C:1 [1] => B:C:a [2] => A:2 [3] => B:b [4] => A:3 [5] => A [6] => B [7] => A:4 )