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; Пример использования функции <function>array_map</function> ]]> В результате переменная $b будет содержать: 1 [1] => 8 [2] => 27 [3] => 64 [4] => 125 ) ]]> Пример работы функции <function>array_map</function> с лямбда-функцией $value * 2, range(1, 5) ) ); ?> ]]> 2 [1] => 4 [2] => 6 [3] => 8 [4] => 10 ) ]]> Пример работы функции <function>array_map</function> с набором массивов $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; вместо названия <parameter>callback</parameter>-функции только с аргументом <parameter>array</parameter> ]]> &example.outputs; int(1) [1]=> int(2) [2]=> int(3) } ]]> Пример обработки функцией <function>array_map</function> строковых ключей '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" } } ]]> Пример работы функции <function>array_map</function> с ассоциативными массивами Хотя функция 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