(PHP 4 >= 4.0.6, PHP 5, PHP 7, PHP 8)
array_map — 為數組的每個(gè)元素應用回調函數
array_map() 返回一個(gè) array,內容為 array 的元素按相應的順序調用
callback 后的結果(如果提供了更多數組,還會(huì )利用 arrays
傳入)。callback 函數形參的數量必須匹配 array_map()
實(shí)參中數組的數量。多余的實(shí)參數組將會(huì )被忽略。如果提供的實(shí)參數組的數量不足,將拋出 ArgumentCountError。
callback回調函數 callable,應用到每個(gè)數組里的每個(gè)元素。
多個(gè)數組操作合并時(shí),callback 可以設置為 null。
如果只提供了 array 一個(gè)數組,
array_map() 會(huì )返回輸入的數組。
array
數組,遍歷運行 callback 函數。
arrays
額外的數組列表,每個(gè)都遍歷運行 callback 函數。
返回數組,包含 callback 函數處理之后 array (有多個(gè)數組時(shí),為 arrays) 對應索引所有元素作為函數的參數。
當僅僅傳入一個(gè)數組時(shí),返回的數組會(huì )保留傳入參數的鍵(key)。 傳入多個(gè)數組時(shí),返回的數組鍵是按順序的 integer。
| 版本 | 說(shuō)明 |
|---|---|
| 8.0.0 |
如果 callback 接受引用傳遞參數,該方法將會(huì )拋出
E_WARNING。
|
示例 #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 "The number {$n} is called {$m} in Spanish";
}
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);
?>
以上例程會(huì )輸出:
// 打印 $c
Array
(
[0] => The number 1 is called uno in Spanish
[1] => The number 2 is called dos in Spanish
[2] => The number 3 is called tres in Spanish
[3] => The number 4 is called cuatro in Spanish
[4] => The number 5 is called cinco in Spanish
)
// 打印 $d
Array
(
[0] => Array
(
[1] => uno
)
[1] => Array
(
[2] => dos
)
[2] => Array
(
[3] => tres
)
[3] => Array
(
[4] => cuatro
)
[4] => Array
(
[5] => cinco
)
)
傳入兩個(gè)及以上的數組時(shí),它們元素數量將會(huì )相同。因為回調函數會(huì )并行地處理相互對應的元素。 如果幾個(gè)數組的元素數量不一致:空元素會(huì )擴展短那個(gè)數組,直到長(cháng)度和最長(cháng)的數組一樣。
此函數有個(gè)有趣的用法:傳入 null 作為回調函數的名稱(chēng),將創(chuàng )建多維數組(一個(gè)數組,內部包含數組。)
示例 #4 多個(gè)數組的合并操作
<?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);
?>
以上例程會(huì )輸出:
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
僅有 array1 時(shí),callback 設置為 null
<?php
$array = [1, 2, 3];
var_dump(array_map(null, $array));
?>
以上例程會(huì )輸出:
array(3) {
[0]=>
int(1)
[1]=>
int(2)
[2]=>
int(3)
}
示例 #6 array_map() 鍵(key)是 string
<?php
$arr = array("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));
?>
以上例程會(huì )輸出:
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() - 關(guān)聯(lián)數組
雖然 array_map() 不能直接支持使用數組的鍵(key)作為輸入,但可以使用 array_keys() 進(jìn)行模擬。
<?php
$arr = [
'v1' => 'First release',
'v2' => 'Second release',
'v3' => 'Third release',
];
// 注意: 在 7.4.0 之前,使用較長(cháng)的語(yǔ)法來(lái)代替匿名函數。
$callback = fn(string $k, string $v): string => "$k was the $v";
$result = array_map($callback, array_keys($arr), array_values($arr));
var_dump($result);
?>
以上例程會(huì )輸出:
array(3) {
[0]=>
string(24) "v1 was the First release"
[1]=>
string(25) "v2 was the Second release"
[2]=>
string(24) "v3 was the Third release"
}