array ( 0 => 'index.php', 1 => 'PHP Manual', ), 'head' => array ( 0 => 'UTF-8', 1 => 'ja', ), 'this' => array ( 0 => 'function.array-diff-key.php', 1 => 'array_diff_key', ), 'up' => array ( 0 => 'ref.array.php', 1 => '配列 関数', ), 'prev' => array ( 0 => 'function.array-diff-assoc.php', 1 => 'array_diff_assoc', ), 'next' => array ( 0 => 'function.array-diff-uassoc.php', 1 => 'array_diff_uassoc', ), 'alternatives' => array ( ), 'source' => array ( 'lang' => 'ja', 'path' => 'reference/array/functions/array-diff-key.xml', ), ); $setup["toc"] = $TOC; $setup["toc_deprecated"] = $TOC_DEPRECATED; $setup["parents"] = $PARENTS; manual_setup($setup); ?>
(PHP 5 >= 5.1.0, PHP 7, PHP 8)
array_diff_key — キーを基準にして配列の差を計算する
array
のキーを
arrays
のキーと比較し、その差を返します。
この関数は array_diff() に似ていますが、
値ではなくキーを用いて比較するという点が異なります。
array
比較元の配列。
arrays
比較する対象となる配列。
array
の要素のうち、
その他の配列のいずれにも含まれないキーのものだけを残した配列を返します。
バージョン | 説明 |
---|---|
8.0.0 | この関数は、引数をひとつだけ渡しても呼び出せるようになりました。 これより前のバージョンでは、少なくともふたつの引数が必須でした。 |
例1 array_diff_key() の例
ふたつの key => value
のペアが等しいとみなされるのは、
(string) $key1 === (string) $key2
である場合のみです。つまり、厳密な型チェックを行うということです。
文字列表現が一致しなければなりません。
<?php
$array1 = array('blue' => 1, 'red' => 2, 'green' => 3, 'purple' => 4);
$array2 = array('green' => 5, 'yellow' => 7, 'cyan' => 8);
var_dump(array_diff_key($array1, $array2));
?>
上の例の出力は以下となります。
array(3) { ["blue"]=> int(1) ["red"]=> int(2) ["purple"]=> int(4) }
<?php
$array1 = array('blue' => 1, 'red' => 2, 'green' => 3, 'purple' => 4);
$array2 = array('green' => 5, 'yellow' => 7, 'cyan' => 8);
$array3 = array('blue' => 6, 'yellow' => 7, 'mauve' => 8);
var_dump(array_diff_key($array1, $array2, $array3));
?>
上の例の出力は以下となります。
array(2) { ["red"]=> int(2) ["purple"]=> int(4) }
注意:
この関数は n 次元配列の一つの次元しかチェックしません。 もちろん、
array_diff_key($array1[0], $array2[0]);
のようにすることでより深い次元でのチェックもできます。