(PHP 4 >= 4.0.6, PHP 5, PHP 7, PHP 8)
array_map — Применяет callback-функцию к элементам массивов
Функция array_map() возвращает массив (array), который содержит
результаты обработки callback
-функцией значений
массива array
,
и значений массивов arrays
, если в функцию передали больше одного массива,
которые функция передаёт как аргументы в callback-функцию.
При вызове функции array_map() проверяют, чтобы количество массивов, которое передают в функцию,
совпадало с количеством параметров callback
-функции.
Функция проигнорирует лишние входные массивы. При передаче недостаточного количества
аргументов функция выбросит исключение ArgumentCountError.
callback
Значение с типом callable, которое функция вызовет на каждом элементе в каждом массиве.
При передаче аргумента callback
со значением null
функция выполнит с массивами zip-операцию и вернёт массив массивов,
каждый из которых содержит элементы входных массивов с одними и теми же индексами,
как в примере ниже.
Функция array_map() вернёт входной массив,
если передали только аргумент array
.
array
Массив, который функция передаст в callback
-функцию.
arrays
Дополнительные массивы для обработки
callback
-функцией.
Функция возвращает массив, который содержит
результаты обработки callback
-функцией значений
массива array
,
и значений массивов arrays
, если в функцию передали больше одного массива,
которые функция передаёт как аргументы в callback-функцию.
Массив, который вернёт функция, сохранит ключи аргумента-массива, только если в функцию передали ровно один массив. Массив, который возвращает функция, будет содержать последовательные целочисленные ключи, если передали больше одного массива.
Версия | Описание |
---|---|
8.0.0 |
Теперь функция выдаст ошибку уровня E_WARNING ,
если параметр callback ожидает,
что значение передадут по ссылке.
|
Пример #1 Пример использования функции array_map()
<?php
function cube($n)
{
return ($n * $n * $n);
}
$a = [1, 2, 3, 4, 5];
$b = array_map('cube', $a);
print_r($b);
?>
В результате переменная $b будет содержать:
Array ( [0] => 1 [1] => 8 [2] => 27 [3] => 64 [4] => 125 )
Пример #2 Пример работы функции array_map() с лямбда-функцией
<?php
$func = function(int $value): int {
return $value * 2;
};
print_r(array_map($func, range(1, 5)));
// Или с PHP 7.4.0:
print_r(
array_map(
fn($value): int => $value * 2,
range(1, 5)
)
);
?>
Array ( [0] => 2 [1] => 4 [2] => 6 [3] => 8 [4] => 10 )
Пример #3 Пример работы функции array_map() с набором массивов
<?php
function show_Spanish(int $n, string $m): string
{
return "Число {$n} по-испански называется {$m}";
}
function map_Spanish(int $n, string $m): array
{
return [$n => $m];
}
$a = [1, 2, 3, 4, 5];
$b = ['uno', 'dos', 'tres', 'cuatro', 'cinco'];
$c = array_map('show_Spanish', $a, $b);
print_r($c);
$d = array_map('map_Spanish', $a, $b);
print_r($d);
?>
Результат выполнения приведённого примера:
// Вывод переменной $c Array ( [0] => Число 1 по-испански называется uno [1] => Число 2 по-испански называется dos [2] => Число 3 по-испански называется tres [3] => Число 4 по-испански называется cuatro [4] => Число 5 по-испански называется cinco ) // Вывод переменной $d Array ( [0] => Array ( [1] => uno ) [1] => Array ( [2] => dos ) [2] => Array ( [3] => tres ) [3] => Array ( [4] => cuatro ) [4] => Array ( [5] => cinco ) )
Обычно при обработке двух и более массивов они имеют одинаковую длину, поскольку callback-функция применяется к элементам массивов параллельно. При обработке массивов разной длины функция расширяет более короткие массивы элементами с пустыми значениями до длины самого длинного массива.
Функция создаёт массив массивов,
когда вместо названия callback-функции передают значение null
.
Пример #4 Выполнение zip-операции с массивами
<?php
$a = [1, 2, 3, 4, 5];
$b = ['one', 'two', 'three', 'four', 'five'];
$c = ['uno', 'dos', 'tres', 'cuatro', 'cinco'];
$d = array_map(null, $a, $b, $c);
print_r($d);
?>
Результат выполнения приведённого примера:
Array ( [0] => Array ( [0] => 1 [1] => one [2] => uno ) [1] => Array ( [0] => 2 [1] => two [2] => dos ) [2] => Array ( [0] => 3 [1] => three [2] => tres ) [3] => Array ( [0] => 4 [1] => four [2] => cuatro ) [4] => Array ( [0] => 5 [1] => five [2] => cinco ) )
Пример #5
Пример работы функции со значением null
вместо названия
callback
-функции только с аргументом array
<?php
$array = [1, 2, 3];
var_dump(array_map(null, $array));
?>
Результат выполнения приведённого примера:
array(3) { [0]=> int(1) [1]=> int(2) [2]=> int(3) }
Пример #6 Пример обработки функцией array_map() строковых ключей
<?php
$arr = ['stringkey' => 'value'];
function cb1($a)
{
return [$a];
}
function cb2($a, $b)
{
return [$a, $b];
}
var_dump(array_map('cb1', $arr));
var_dump(array_map('cb2', $arr, $arr));
var_dump(array_map(null, $arr));
var_dump(array_map(null, $arr, $arr));
?>
Результат выполнения приведённого примера:
array(1) { ["stringkey"]=> array(1) { [0]=> string(5) "value" } } array(1) { [0]=> array(2) { [0]=> string(5) "value" [1]=> string(5) "value" } } array(1) { ["stringkey"]=> string(5) "value" } array(1) { [0]=> array(2) { [0]=> string(5) "value" [1]=> string(5) "value" } }
Пример #7 Пример работы функции array_map() с ассоциативными массивами
Хотя функция array_map() напрямую не поддерживает входные данные в виде ключей массива, это можно сымитировать через функцию array_keys().
<?php
$arr = [
'v1' => 'Первому выпуску',
'v2' => 'Второму выпуску',
'v3' => 'Третьему выпуску',
];
// Примечание: До версии 7.4.0 анонимные функции записывают длинным, а не коротким синтаксисом
$callback = fn(string $k, string $v): string => "$v присвоили версию $k";
$result = array_map($callback, array_keys($arr), array_values($arr));
var_dump($result);
?>
Результат выполнения приведённого примера:
array(3) { [0]=> string(64) "Первому выпуску присвоили версию v1" [1]=> string(64) "Второму выпуску присвоили версию v2" [2]=> string(66) "Третьему выпуску присвоили версию v3" }