(PHP 4 >= 4.0.6, PHP 5, PHP 7, PHP 8)
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. |
8.0.0 | Теперь функция выдаст ошибку уровня E_WARNING , если параметр callback-функции, переданной в параметр callback , ожидает передачу значения по ссылке. |
Пример #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-функция изменяет массив (например, добавляет или удаляет элементы), поведение этой функции неопределённо.