Фильтрует элементы массива с помощью callback-функции


(PHP 4 >= 4.0.6, PHP 5)

array_filterФильтрует элементы массива с помощью callback-функции

Описание

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

Обходит каждое значение массива array, передавая его в callback-функцию. Если callback-функция возвращает true, данное значение из array возвращается в результирующий массив. Ключи массива сохраняются.

Список параметров

array

Итерируемый массив

callback

Используемая callback-функция

Если callback-функция не передана, все значения массива array равные FALSE (см. преобразование в булевый тип) будут удалены.

flag

Флаг определяющий какие аргументы передавать в callback:

  • ARRAY_FILTER_USE_KEY - передавать только ключ массива как аргумент для callback вместо значения
  • ARRAY_FILTER_USE_BOTH - передавать и ключ и значение в callback вместо толкьо значения

Возвращаемые значения

Возвращает отфильтрованный массив.

Список изменений

Версия Описание
5.6.0 Добавлен необязательный параметр flag и константы ARRAY_FILTER_USE_KEY и ARRAY_FILTER_USE_BOTH

Примеры

Пример #1 Пример использования array_filter()

<?php
function odd($var)
{
    
// является ли переданное число нечетным
    
return($var 1);
}

function 
even($var)
{
    
// является ли переданное число четным
    
return(!($var 1));
}

$array1 = array("a"=>1"b"=>2"c"=>3"d"=>4"e"=>5);
$array2 = array(6789101112);

echo 
"Нечетные:\n";
print_r(array_filter($array1"odd"));
echo 
"Четные:\n";
print_r(array_filter($array2"even"));
?>

Результат выполнения данного примера:

 Нечетные: Array (     [a] => 1     [c] => 3     [e] => 5 ) Четные: Array (     [0] => 6     [2] => 8     [4] => 10     [6] => 12 ) 

Пример #2 Использование array_filter() без callback-функции

<?php

$entry 
= array(
             
=> 'foo',
             
=> false,
             
=> -1,
             
=> null,
             
=> ''
          
);

print_r(array_filter($entry));
?>

Результат выполнения данного примера:

 Array (     [0] => foo     [2] => -1 ) 

Пример #3 array_filter() с указанным 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));
?>

Результат выполнения данного примера:

 array(1) {   ["b"]=>   int(2) } array(2) {   ["b"]=>   int(2)   ["d"]=>   int(4) } 

Примечания

Предостережение

Если callback-функция изменяет массив (например, добавляет или удаляет элементы), поведение этой функции неопределено.

Смотрите также

  • array_map() - Применяет callback-функцию ко всем элементам указанных массивов
  • array_reduce() - Итеративно уменьшает массив к единственному значению, используя callback-функцию
  • array_walk() - Применяет заданную пользователем функцию к каждому элементу массива