(PHP 4 >= 4.0.6, PHP 5, PHP 7)
array_filter — Filtra elementos de um array utilizando uma função callback
Itera sobre cada valor de
array
passando-os para a função
callback
. Se a função
callback
retornar true, o valor atual de
array
é retornado na matriz resultado. As chaves do array são preservadas.
array
O array a ser iterado
callback
A função callback a ser usada
Se nenhum callback
é fornecido, todas entradas de
array
iguais a FALSE
(veja
convertendo para
booleano) serão removidas.
flag
Flag determina quais argumentos são passadosoara o parâmetro callback
:
ARRAY_FILTER_USE_KEY
- passa chaves como argumentos
para callback
em vez de valor
ARRAY_FILTER_USE_BOTH
- passa tanto valor quanto chave como
argumento para callback
em vez do valor
Retorna o array filtrado.
Versão | Descrição |
---|---|
5.6.0 |
Adicionado o parâmetro opcional flag e as contantes
ARRAY_FILTER_USE_KEY e
ARRAY_FILTER_USE_BOTH
|
Exemplo #1 Exemplo da função array_filter()
<?php
function impar($var)
{
// retorna se o inteiro informado é impar
return($var & 1);
}
function par($var)
{
// retorna se o inteiro informado é par
return(!($var & 1));
}
$array1 = array("a" => 1, "b" => 2, "c" => 3, "d" => 4, "e" => 5);
$array2 = array(6, 7, 8, 9, 10, 11, 12);
echo "Impares: \n";
print_r(array_filter($array1, "impar"));
echo "Pares: \n";
print_r(array_filter($array2, "par"));
?>
O exemplo acima irá imprimir:
Impares: Array ( [a] => 1 [c] => 3 [e] => 5 ) Pares: Array ( [0] => 6 [2] => 8 [4] => 10 [6] => 12 )
Exemplo #2 array_filter() sem
callback
<?php
$entry = array(
0 => 'foo',
1 => false,
2 => -1,
3 => null,
4 => ''
);
print_r(array_filter($entry));
?>
O exemplo acima irá imprimir:
Array ( [0] => foo [2] => -1 }
Exemplo #3 array_filter() com
flag
<?php
$arr = ['a' => 1, 'b' => 2, 'c' => 3, 'd' => 4];
var_dump(array_filter($arr, function($k) {
return $k == 'b';
}, ARRAY_FILTER_USE_KEY));
var_dump(array_filter($arr, function($v, $k) {
return $k == 'b' || $v == 4;
}, ARRAY_FILTER_USE_BOTH));
?>
O exemplo acima irá imprimir:
array(1) { ["b"]=> int(2) } array(2) { ["b"]=> int(2) ["d"]=> int(4) }
Se o array é modificado por uma função callback (e.g. elemento adicionado, deletado ou apagado) o comportamento desta função é indefinido.