2011-08-18 13 views

Respuesta

2
$keys = array_keys($B); 
$C = array(); 
foreach ($A as $key => $value) 
{ 
    if (in_array($key, $keys)) 
    { 
    $C[$key] = $value; 
    } 
} 
+0

Gracias por la respuesta. – Fazri

2

Aquí hay una solución simple que comprueba que existe la llave en $A antes de añadir 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" 
} 
+0

Obviamente mal: /. OP necesita filtrar una matriz con otra, su solución no. Y el resultado en '$ C' debe ser una matriz asociativa, en su solución es una indexada. –

+0

Editado para hacer '$ C' asociativo –

+0

Obviamente funciona entonces;) –

16
$keys = array_flip($B); 
$C = array_intersect_key($A,$keys); 
1

Para mi inmensa sorpresa, el método bucle foreach es más rápido.

La siguiente secuencia de comandos de referencia rápida me da los resultados: 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"; 
+1

Awesome \ o/(y algunos personajes más para llegar a 15). –

Cuestiones relacionadas