array_map
指定した配列の要素にコールバック関数を適用する
&reftitle.description;
arrayarray_map
callablenullcallback
arrayarray
arrayarrays
array_map は、array
(および、 それ以上の配列が与えられた場合は arrays)
の各要素に callback を適用した後、
適用後の要素を含む &array; を返します。
callback 関数が受け付けるパラメータの数は、
array_map に渡される配列の数に一致している必要があります。
それより配列の数が多かった場合、溢れた分は無視されます。
少なかった場合、ArgumentCountError がスローされます。
&reftitle.parameters;
callback
配列の各要素に適用する callable。
複数の配列に zip 操作を行い、
返される配列の要素を、
入力された配列の要素と同じインデックスをそれぞれ保持した配列にすることができます。
こうするためには、callback に &null; を渡します(以下の例を参照ください)。
array のみが与えられた場合、
array_map は、入力された配列を返します。
array
コールバック関数を適用する配列。
arrays
callback に渡す引数を指定する配列の可変リスト。
&reftitle.returnvalues;
array
(および、 それ以上の配列が与えられた場合は arrays)
の各要素に callback 関数を適用した後、
適用後の要素を含む &array; を返します。
引数で渡した配列のキーがそのまま維持されるのは、渡した配列がひとつだけである場合のみです。
複数の配列を渡した場合は、戻り値の配列のキーは整数値が振り直されます。
&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;
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; を使用することにより、簡単に実行できるものです。
配列の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 を使うと、配列のキーを入力とした動きをシミュレートできます。
'First release',
'v2' => 'Second release',
'v3' => 'Third release',
];
// Note: 7.4.0 より前のバージョンでは、無名関数を使うにはもっと長い書き方を使う必要があります
$callback = fn(string $k, string $v): string => "$k was the $v";
$result = array_map($callback, array_keys($arr), array_values($arr));
var_dump($result);
?>
]]>
&example.outputs;
string(24) "v1 was the First release"
[1]=>
string(25) "v2 was the Second release"
[2]=>
string(24) "v3 was the Third release"
}
]]>
&reftitle.seealso;
array_filter
array_reduce
array_walk