9

連想配列とキーの配列があります。

$A = array('a'=>'book', 'b'=>'pencil', 'c'=>'pen');
$B = array('a', 'b');

$Aキーがある場所のすべての要素から連想配列を作成するにはどうすればよい$Bですか? 上記の例の場合、答えは次のようになります。

$C = array('a'=>'book', 'b'=>'pencil');
4

5 に答える 5

19
$keys = array_flip($B);
$C = array_intersect_key($A,$keys);
于 2011-08-18T13:23:03.990 に答える
4

array_intersect_key($A,array_combine($B,$B))

またはそれ以上:array_intersect_key($my_array, array_flip($allowed))

質問から: PHP: array_filter() を使用して配列キーをフィルタリングする方法は?

于 2011-08-18T13:21:34.943 に答える
2

$Aこれは、キーを追加する前にキーが存在することを確認する簡単なソリューションです。$C

$A = array('a'=>'book', 'b'=>'pencil', 'c'=>'pen');
$B = array('a', 'b');

$C = array();
foreach ($B as $bval) {
  // If the $B key exists in $A, add it to $C
  if (isset($A[$bval])) $C[$bval] = $A[$bval];
}

var_dump($C);

// Prints:
array(2) {
  ["a"]=>
  string(4) "book"
  ["b"]=>
  string(6) "pencil"
}
于 2011-08-18T13:13:25.097 に答える
1
$keys = array_keys($B);
$C = array();
foreach ($A as $key => $value)
{
  if (in_array($key, $keys))
  {
    $C[$key] = $value;
  }
}
于 2011-08-18T13:13:51.593 に答える
1

非常に驚いたことに、foreach ループ メソッドの方が高速です。

次の簡単なベンチマーク スクリプトで結果が得られます。 array_intersect_key: 0.76424908638 foreach loop: 0.6393928527832

$A = array('a'=>'book', 'b'=>'pencil', 'c'=>'pen');
$B = array('a', 'b');

$start = microtime(true);
for ($i = 0 ; $i < 1000000; $i++) {
$c = array_intersect_key($A,array_flip($B));
}

$t1 = microtime(true);

for ($i = 0; $i < 1000000; $i++) {
$C = array();
    foreach ($B as $bval) {
          // If the $B key exists in $A, add it to $C
          if (isset($A[$bval])) $C[$bval] = $A[$bval];
    }
}

$t2 = microtime(true);
echo "array_intersect_key: " . ($t1 - $start), "\n";
echo "foreach loop: " . ($t2 - $t1), "\n";
于 2011-08-18T13:43:28.427 に答える