2011-08-18 19 views

Odpowiedz

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

Dzięki za odpowiedź. – Fazri

2

Oto proste rozwiązanie, które sprawdza, czy klucz istnieje w $A przed dołączenie go do $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

Oczywiście nie tak: /. OP musi filtrować tablicę z innym, twoje rozwiązanie nie. A wynik w '$ C' powinien być tablicą asocjacyjną, w twoim rozwiązaniu jest zindeksowany. –

+0

Zmienione, aby stowarzyszenie '$ C' asocjacyjne –

+0

Oczywiście działa wtedy;) –

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

Do mojego ogromnego zaskoczenia, metoda pętli foreach jest szybsze.

Poniższy skrypt szybkie odniesienia daje mi wyniki: 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/(i trochę więcej postaci, aby osiągnąć 15). –