(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().