array ( 0 => 'index.php', 1 => 'PHP Manual', ), 'head' => array ( 0 => 'UTF-8', 1 => 'ja', ), 'this' => array ( 0 => 'function.array-intersect-key.php', 1 => 'array_intersect_key', ), 'up' => array ( 0 => 'ref.array.php', 1 => '配列 関数', ), 'prev' => array ( 0 => 'function.array-intersect-assoc.php', 1 => 'array_intersect_assoc', ), 'next' => array ( 0 => 'function.array-intersect-uassoc.php', 1 => 'array_intersect_uassoc', ), 'alternatives' => array ( ), 'source' => array ( 'lang' => 'ja', 'path' => 'reference/array/functions/array-intersect-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_intersect_key — キーを基準にして配列の共通項を計算する
array_intersect_key() は、
array
のエントリのうち、
その他のすべての引数の中に共通して存在するキーと一致するキーの値からなる配列を返します。
array
値を調べるもととなる配列。
arrays
キーを比較する対象となる配列。
array
のエントリのうち、
すべての引数に存在するキーのものを含む連想配列を返します。
バージョン | 説明 |
---|---|
8.0.0 | この関数は、引数をひとつだけ渡しても呼び出せるようになりました。 これより前のバージョンでは、少なくともふたつの引数が必須でした。 |
例1 array_intersect_key() の例
<?php
$array1 = array('blue' => 1, 'red' => 2, 'green' => 3, 'purple' => 4);
$array2 = array('green' => 5, 'blue' => 6, 'yellow' => 7, 'cyan' => 8);
var_dump(array_intersect_key($array1, $array2));
?>
上の例の出力は以下となります。
array(2) { ["blue"]=> int(1) ["green"]=> int(3) }
この例では、両方の配列に存在するキーが 'blue'
と 'green'
だけであり、それが返されていることが
わかります。また、ふたつの配列の間で 'blue'
と
'green'
に対応する値が違うことにも注意しましょう。
それでも一致していると判定されるのは、ただキーだけがチェックされているからです。
返される値は array
のものです。
二つの要素は、
(string) $elem1 === (string) $elem2
の場合のみ等しいとみなされます。言い換えると、
文字列表現が同じ場合となります。