array_filter
(PHP 4 >= 4.0.6, PHP 5, PHP 7)
array_filter — Фильтрует элементы массива с помощью callback-функции
Описание
Обходит каждое значение массива array
,
передавая его в callback
-функцию. Если
callback
-функция возвращает true
, данное
значение из array
возвращается в результирующий array.
Ключи массива сохраняются и могут привести к пропускам, если array
был проиндексирован.
Результат массива (array) можно переиндексировать с помощью функции array_values().
Список параметров
-
array
-
Итерируемый массив
-
callback
-
Используемая callback-функция
Если
callback
-функция не передана, все пустые значения массиваarray
будут удалены. Смотрите empty(), чтобы узнать, как PHP определяет пустое значение в этом случае. -
mode
-
Флаг, определяющий, какие аргументы передавать в
callback
:-
ARRAY_FILTER_USE_KEY
- передавать только ключ массива как аргумент дляcallback
вместо значения -
ARRAY_FILTER_USE_BOTH
- передавать и ключ, и значение вcallback
вместо только значения
0
, что означает, что вcallback
-функцию будет передаваться только значение в качестве единственного аргумента. -
Возвращаемые значения
Возвращает отфильтрованный массив.
Список изменений
Версия | Описание |
---|---|
8.0.0 |
callback теперь допускает значение null.
|
5.6.0 |
Добавлен необязательный параметр mode и константы
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 = ['a' => 1, 'b' => 2, 'c' => 3, 'd' => 4, 'e' => 5];
$array2 = [6, 7, 8, 9, 10, 11, 12];
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 = [
0 => 'foo',
1 => false,
2 => -1,
3 => null,
4 => '',
5 => '0',
6 => 0,
];
print_r(array_filter($entry));
?>
Результат выполнения данного примера:
Array ( [0] => foo [2] => -1 )
Пример #3 array_filter() с указанным
mode
<?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() - Применяет заданную пользователем функцию к каждому элементу массива