array_map
Применяет callback-функцию к элементам массивов
&reftitle.description;
arrayarray_map
callablenullcallback
arrayarray
arrayarrays
Функция array_map возвращает массив (&array;), который содержит
результаты обработки callback-функцией значений
массива array,
и значений массивов arrays, если в функцию передали больше одного массива,
которые функция передаёт как аргументы в callback-функцию.
При вызове функции array_map проверяют, чтобы количество массивов, которое передают в функцию,
совпадало с количеством параметров callback-функции.
Функция проигнорирует лишние входные массивы. При передаче недостаточного количества
аргументов функция выбросит исключение ArgumentCountError.
&reftitle.parameters;
callback
Значение с типом callable, которое функция вызовет
на каждом элементе в каждом массиве.
При передаче аргумента callback со значением &null;
функция выполнит с массивами zip-операцию и вернёт массив массивов,
каждый из которых содержит элементы входных массивов с одними и теми же индексами,
как в примере ниже.
Функция array_map вернёт входной массив,
если передали только аргумент array.
array
Массив, который функция передаст в callback-функцию.
arrays
Дополнительные массивы для обработки
callback-функцией.
&reftitle.returnvalues;
Функция возвращает массив, который содержит
результаты обработки callback-функцией значений
массива array,
и значений массивов arrays, если в функцию передали больше одного массива,
которые функция передаёт как аргументы в callback-функцию.
Массив, который вернёт функция, сохранит ключи аргумента-массива,
только если в функцию передали ровно один массив. Массив, который возвращает функция,
будет содержать последовательные целочисленные ключи, если передали больше одного массива.
&reftitle.changelog;
&Version;
&Description;
&array.changelog.by-ref;
&reftitle.examples;
Пример использования функции array_map
]]>
В результате переменная $b будет содержать:
1
[1] => 8
[2] => 27
[3] => 64
[4] => 125
)
]]>
Пример работы функции array_map с лямбда-функцией
$value * 2,
range(1, 5)
)
);
?>
]]>
2
[1] => 4
[2] => 6
[3] => 8
[4] => 10
)
]]>
Пример работы функции array_map с набором массивов
$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);
?>
]]>
&example.outputs;
Число 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;.
Выполнение zip-операции с массивами
]]>
&example.outputs;
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
)
)
]]>
Пример работы функции со значением &null; вместо названия
callback-функции только с аргументом array
]]>
&example.outputs;
int(1)
[1]=>
int(2)
[2]=>
int(3)
}
]]>
Пример обработки функцией array_map строковых ключей
'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));
?>
]]>
&example.outputs;
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"
}
}
]]>
Пример работы функции array_map с ассоциативными массивами
Хотя функция array_map напрямую не поддерживает
входные данные в виде ключей массива,
это можно сымитировать через функцию array_keys.
'Первому выпуску',
'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);
?>
]]>
&example.outputs;
string(64) "Первому выпуску присвоили версию v1"
[1]=>
string(64) "Второму выпуску присвоили версию v2"
[2]=>
string(66) "Третьему выпуску присвоили версию v3"
}
]]>
&reftitle.seealso;
array_filter
array_reduce
array_walk