preg_filter

(PHP 5 >= 5.3.0, PHP 7, PHP 8)

preg_filterExecuta pesquisa e substituição usando expressões regulares

Descrição

preg_filter(
    string|array $pattern,
    string|array $replacement,
    string|array $subject,
    int $limit = -1,
    int &$count = null
): string|array|null

preg_filter() é idêntica a preg_replace() exceto que ela somente retorna strings de entrada (possivelmente transformadas) onde ocorreu uma correspondência. Para detalhes sobre como esta função trabalha, leia a documentação sobre preg_replace().

Parâmetros

Parâmetros estão descritos na documentação sobre preg_replace().

Valor Retornado

Retorna um array se o parâmetro subject for um array, ou uma string caso contrário.

Se nenhuma correspondência for encontrada ou se ocorrer um erro, um array vazio é retornado quando subject for um array ou null caso contrário.

Erros/Exceções

Se o padrão de expressão regular passado não for compilado para uma expressão regular válida, um E_WARNING será emitido.

Exemplos

Example #1 Exemplo comparando preg_filter() com preg_replace()

<?php
$subject = array('1', 'a', '2', 'b', '3', 'A', 'B', '4');
$pattern = array('/\d/', '/[a-z]/', '/[1a]/');
$replace = array('A:$0', 'B:$0', 'C:$0');

echo "preg_filter retorna\n";
print_r(preg_filter($pattern, $replace, $subject));

echo "preg_replace retorna\n";
print_r(preg_replace($pattern, $replace, $subject));
?>

O exemplo acima produzirá:

preg_filter retorna
Array
(
    [0] => A:C:1
    [1] => B:C:a
    [2] => A:2
    [3] => B:b
    [4] => A:3
    [7] => A:4
)
preg_replace retorna
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
)

Veja Também