Php/docs/function.array-map

来自菜鸟教程
跳转至:导航、​搜索

array_map

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

array_map 为数组的每个元素应用回调函数


说明

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

array_map():返回数组,是为 array 每个元素应用 callback函数之后的数组。 array_map() 返回一个 array,数组内容为 array1 的元素按索引顺序为参数调用 callback 后的结果(有更多数组时,还会传入 arrays 的元素)。 callback 函数形参的数量必须匹配 array_map() 实参中数组的数量。


参数

callback

回调函数 callable,应用到每个数组里的每个元素。

多个数组操作合并时,callback 可以设置为 null。 如果只提供了 array 一个数组, array_map() 会返回输入的数组。

array

数组,遍历运行 callback 函数。

arrays

额外的数组列表,每个都遍历运行 callback 函数。


返回值

返回数组,包含 callback 函数处理之后 array (有多个数组时,为 arrays) 对应索引所有元素作为函数的参数。

当仅仅传入一个数组时,返回的数组会保留传入参数的键(key)。 传入多个数组时,返回的数组键是按顺序的 integer。


范例

Example #1 array_map() 例子

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

Example #2 array_map() 使用匿名函数 (PHP 5.3.0 起)

<?php$func = function($value) {    return $value * 2;};print_r(array_map($func, range(1, 5)));?>

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

Example #3 array_map():使用更多的数组

<?phpfunction show_Spanish($n, $m){    return "The number {$n} is called {$m} in Spanish";}function map_Spanish($n, $m){    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);?>

以上例程会输出:


// printout of $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
)

// printout of $d
Array
(
    [0] => Array
        (
            [1] => uno
        )

    [1] => Array
        (
            [2] => dos
        )

    [2] => Array
        (
            [3] => tres
        )

    [3] => Array
        (
            [4] => cuatro
        )

    [4] => Array
        (
            [5] => cinco
        )

)

传入两个及以上的数组时,它们元素数量将会相同。因为回调函数会并行地处理相互对应的元素。 如果几个数组的元素数量不一致:空元素会扩展短那个数组,直到长度和最长的数组一样。

此函数有个有趣的用法:传入 null 作为回调函数的名称,将创建多维数组(一个数组,内部包含数组。)

Example #4 多个数组的合并操作

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

)

Example #5 仅有 array1 时,callback 设置为 null'

<?php$array = [1, 2, 3];var_dump(array_map(null, $array));?>

以上例程会输出:


array(3) {
  [0]=>
  int(1)
  [1]=>
  int(2)
  [2]=>
  int(3)
}

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

参见

  • array_filter() - 用回调函数过滤数组中的单元
  • array_reduce() - 用回调函数迭代地将数组简化为单一的值
  • array_walk() - 使用用户自定义函数对数组中的每个元素做回调处理