Funções para Array
PHP Manual

array_filter

(PHP 4 >= 4.0.6, PHP 5, PHP 7)

array_filterFiltra elementos de um array utilizando uma função callback

Descrição

array array_filter ( array $array [, callable $callback [, int $flag = 0 ]] )

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.

Parâmetros

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

Valor Retornado

Retorna o array filtrado.

Changelog

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

Exemplos

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(6789101112);

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(
             
=> 'foo',
             
=> false,
             
=> -1,
             
=> null,
             
=> ''
          
);

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)
}

Notas

Cuidado

Se o array é modificado por uma função callback (e.g. elemento adicionado, deletado ou apagado) o comportamento desta função é indefinido.

Veja Também


Funções para Array
PHP Manual