(PHP 5 >= 5.3.0, PHP 7)
array_replace_recursive — 渡された配列の要素を再帰的に置き換える
$array1
, array $array2
[, array $...
] )array_replace_recursive() は、 最初の配列の値をそれ以降の配列の同じ要素の値で置き換えます。 最初の配列のキーと同じキーが 2 番目の配列にあれば、 2 番目の配列の値が最初の配列の値を上書きします。 2 番目の配列に存在するキーが最初の配列に存在しなければ、 そのキーが新たに最初の配列内に作られます。 最初の配列にしか存在しないキーについては何も変わりません。 置き換え用の配列が複数渡された場合は渡した順に処理を行い、 後から渡した配列の値のほうが優先されます。
array_replace_recursive() は再帰的な処理を行います。 配列を再帰的にたどり、内部の値に対しても同じ手順で処理します。
array1
の値がスカラーの場合は、
array2
の値がスカラーであるか配列であるかにかかわらずそれで置き換えられます。
array1
の値と array2
の値が両方配列である場合は、array_replace_recursive()
が対応する値を再帰的に処理します。
array1
要素を置き換えたい配列。
array2
置き換えたい要素を含む配列。
...
オプション。置き換えたい要素を含む、さらに別の配列。
配列を返します。エラーが発生した場合は NULL
を返します。
例1 array_replace_recursive() の例
<?php
$base = array('citrus' => array( "orange") , 'berries' => array("blackberry", "raspberry"), );
$replacements = array('citrus' => array('pineapple'), 'berries' => array('blueberry'));
$basket = array_replace_recursive($base, $replacements);
print_r($basket);
$basket = array_replace($base, $replacements);
print_r($basket);
?>
上の例の出力は以下となります。
Array ( [citrus] => Array ( [0] => pineapple ) [berries] => Array ( [0] => blueberry [1] => raspberry ) ) Array ( [citrus] => Array ( [0] => pineapple ) [berries] => Array ( [0] => blueberry ) )
例2 array_replace_recursive() での再帰的な挙動の例
<?php
$base = array('citrus' => array("orange") , 'berries' => array("blackberry", "raspberry"), 'others' => 'banana' );
$replacements = array('citrus' => 'pineapple', 'berries' => array('blueberry'), 'others' => array('litchis'));
$replacements2 = array('citrus' => array('pineapple'), 'berries' => array('blueberry'), 'others' => 'litchis');
$basket = array_replace_recursive($base, $replacements, $replacements2);
print_r($basket);
?>
上の例の出力は以下となります。
Array ( [citrus] => Array ( [0] => pineapple ) [berries] => Array ( [0] => blueberry [1] => raspberry ) [others] => litchis )