= 4.0.6, PHP 5, PHP 7, PHP 8)array_map — 為數(shù)組的每個元素應(yīng)用回調(diào)函數(shù) 說明array_map(?callable $callback, array $array, array ...$arrays): arrayarray_">

array_map

(PHP 4 >= 4.0.6, PHP 5, PHP 7, PHP 8)

array_map 為數(shù)組的每個元素應(yīng)用回調(diào)函數(shù)

說明

array_map(?callable $callback, array $array, array ...$arrays): array

array_map() 返回一個 array,內(nèi)容為 array 的元素按相應(yīng)的順序調(diào)用 callback 后的結(jié)果(如果提供了更多數(shù)組,還會利用 arrays 傳入)。callback 函數(shù)形參的數(shù)量必須匹配 array_map() 實參中數(shù)組的數(shù)量。多余的實參數(shù)組將會被忽略。如果提供的實參數(shù)組的數(shù)量不足,將拋出 ArgumentCountError。

參數(shù)

callback

回調(diào)函數(shù) callable,應(yīng)用到每個數(shù)組里的每個元素。

多個數(shù)組操作合并時,callback 可以設(shè)置為 null。 如果只提供了 array 一個數(shù)組, array_map() 會返回輸入的數(shù)組。

array

數(shù)組,遍歷運(yùn)行 callback 函數(shù)。

arrays

額外的數(shù)組列表,每個都遍歷運(yùn)行 callback 函數(shù)。

返回值

返回數(shù)組,包含 callback 函數(shù)處理之后 array (有多個數(shù)組時,為 arrays) 對應(yīng)索引所有元素作為函數(shù)的參數(shù)。

當(dāng)僅僅傳入一個數(shù)組時,返回的數(shù)組會保留傳入?yún)?shù)的鍵(key)。 傳入多個數(shù)組時,返回的數(shù)組鍵是按順序的 integer。

更新日志

版本 說明
8.0.0 如果 callback 接受引用傳遞參數(shù),該方法將會拋出 E_WARNING。

范例

示例 #1 array_map() 例子

<?php
function cube($n)
{
    return (
$n $n $n);
}

$a = [12345];
$b array_map('cube'$a);
print_r($b);
?>

這使得 $b 成為:

Array
(
    [0] => 1
    [1] => 8
    [2] => 27
    [3] => 64
    [4] => 125
)

示例 #2 array_map() 使用匿名函數(shù)

<?php
$func 
= function(int $value): int {
    return 
$value 2;
};

print_r(array_map($funcrange(15)));

// 或者從 PHP 7.4.0 起:

print_r(array_map(fn($value): int => $value 2range(15)));

?>
Array
(
    [0] => 2
    [1] => 4
    [2] => 6
    [3] => 8
    [4] => 10
)

示例 #3 array_map():使用更多的數(shù)組

<?php
function show_Spanish(int $nstring $m): string
{
    return 
"The number {$n} is called {$m} in Spanish";
}

function 
map_Spanish(int $nstring $m): array
{
    return [
$n => $m];
}

$a = [12345];
$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] => 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
        )

)

傳入兩個及以上的數(shù)組時,它們元素數(shù)量將會相同。因為回調(diào)函數(shù)會并行地處理相互對應(yīng)的元素。 如果幾個數(shù)組的元素數(shù)量不一致:空元素會擴(kuò)展短那個數(shù)組,直到長度和最長的數(shù)組一樣。

此函數(shù)有個有趣的用法:傳入 null 作為回調(diào)函數(shù)的名稱,將創(chuàng)建多維數(shù)組(一個數(shù)組,內(nèi)部包含數(shù)組。)

示例 #4 多個數(shù)組的合并操作

<?php
$a 
= [12345];
$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 僅有 array1 時,callback 設(shè)置為 null

<?php
$array 
= [123];
var_dump(array_map(null$array));
?>

以上例程會輸出:

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));
?>

以上例程會輸出:

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)數(shù)組

雖然 array_map() 不能直接支持使用數(shù)組的鍵(key)作為輸入,但可以使用 array_keys() 進(jìn)行模擬。

<?php
$arr 
= [
    
'v1' => 'First release',
    
'v2' => 'Second release',
    
'v3' => 'Third release',
];

// 注意: 在 7.4.0 之前,使用較長的語法來代替匿名函數(shù)。
$callback fn(string $kstring $v): string => "$k was the $v";

$result array_map($callbackarray_keys($arr), array_values($arr));

var_dump($result);
?>

以上例程會輸出:

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"
}

參見

  • array_filter() - 使用回調(diào)函數(shù)過濾數(shù)組的元素
  • array_reduce() - 用回調(diào)函數(shù)迭代地將數(shù)組簡化為單一的值
  • array_walk() - 使用用戶自定義函數(shù)對數(shù)組中的每個元素做回調(diào)處理