(PHP 4 >= 4.0.6, PHP 5, PHP 7)
array_filter — Фильтрует элементы массива с помощью callback-функции
Обходит каждое значение массива 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(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 = array(
0 => 'foo',
1 => false,
2 => -1,
3 => null,
4 => ''
);
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-функция изменяет массив (например, добавляет или удаляет элементы), поведение этой функции неопределено.