2011-08-18 13 views

cevap

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

Cevabınız için teşekkürler. – Fazri

2

olmalıdır İşte $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

Açıkçası yanlış:/

aşağıdaki hızlı kriter komut bana sonuçlar verir. OP bir diziyi bir diğeriyle filtrelemeli, çözümünüz bulunmuyor. Ve '$ C''deki sonuç bir ilişkisel dizi olmalı, çözümünüzde dizine eklenmiş. –

+0

'$ C' ilişkilendirici –

+0

yapmak için düzenlenmiş Açıkçası o zaman çalışıyor;) –

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

benim muazzam sürpriz, foreach döngüsü yöntemi daha hızlıdır. 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/(ve daha fazla karakter 15'e ulaşacak). –

İlgili konular