(PHP 4 >= 4.0.6, PHP 5)
array_filter — Filtra gli elementi di un array usando una funzione callback
array_filter() esegue un'iterazione su ogni valore
nell' array input
passandolo alla
funzione
. Se
funzione
restituisce TRUE
, il valore corrente
di input
viene restituito nell'array
risultato. Le chiavi sono mantenute.
Example #1 Esempio di array_filter()
<?php
function dispari($var)
{
return($var % 2 == 1);
}
function pari($var)
{
return($var % 2 == 0);
}
$array1 = array("a"=>1, "b"=>2, "c"=>3, "d"=>4, "e"=>5);
$array2 = array(6, 7, 8, 9, 10, 11, 12);
echo "Dispari :\n";
print_r(array_filter($array1, "dispari");
echo "Pari :\n";
print_r(array_filter($array2, "pari");
?>
Il precedente esempio visualizzerà:
Dispari : Array ( [a] => 1 [c] => 3 [e] => 5 ) Pari: Array ( [0] => 6 [2] => 8 [4] => 10 [6] => 12 )
Gli utenti non possono modificare l'array attraverso la funzione di callback, ad esempio aggiungere/togliere un elemento, o cancellare l'array su cui array_filter() è applicata. Se l'array viene cambiato, il comportamento di questa funzione non è definito.
Se la funzione callback
non viene indicata,
array_filter() rimuoverà tutti gli elementi di
input
che siano uguali a FALSE
. Vedere conversione a boolean
per ulteriori informazioni.
Example #2 array_filter() senza
callback
<?php
$entry = array(
0 => 'pippo',
1 => false,
2 => -1,
3 => null,
4 => ''
);
print_r(array_filter($entry));
?>
Il precedente esempio visualizzerà:
Array ( [0] => pippo [2] => -1 )
Vedere anche array_map() e array_reduce().