2011-11-01 18 views
7

Sé que esto se logra fácilmente con un foreach, luego un while -> lista, etc procedimiento, (ya lo he logrado), sin embargo, siento que mi código está un poco sucio y no 't parecen la mejor solución ... estoy buscando a utilizar un arreglo de funciones nativas de PHP para hacer lo siguiente:Arreglos de fusión PHP por valor

que tienen dos matrices que se ven así:

 
[0] (Array)#2 
    [rank] "579" 
    [id] "1" 
[1] (Array)#4 
    [rank] "251" 
    [id] "2" 

[0] (Array)#2 
    [size] "S" 
    [status] "A" 
    [id] "1" 
[1] (Array)#15 
    [size] "L" 
    [status] "A" 
    [id] "2" 

y necesito como una resultado algo como lo siguiente:

 
[0] (Array)#2 
    [size] "S" 
    [status] "A" 
    [id] "1" 
    [rank] "579" 

[1] (Array)#2 
    [size] "L" 
    [status] "A" 
    [id] "2" 
    [rank] "251" 

¿Hay alguna manera de poder unir dos matrices con el valor id (u otras) sin entrar en un conjunto interminable de foreach s?

+0

¿Hay elementos con la misma identificación en el mismo índice en ambas matrices? En otras palabras, si el elemento con id 5 está en el índice 3 en la primera matriz, ¿estará también en el índice 3 en la segunda matriz? – deviousdodo

Respuesta

13

Uso array_merge_recursive()

$array = array_merge_recursive($array1, $array2); 

o hacer su propia función (que puede ser más rápido)

function my_array_merge(&$array1, &$array2) { 
    $result = Array(); 
    foreach($array1 as $key => &$value) { 
     $result[$key] = array_merge($value, $array2[$key]); 
    } 
    return $result; 
} 
$array = my_array_merge($array1, array2); 
print_r($array); 
+0

¡Impresionante !, gracias por esto, FYI: el enfoque de la función funciona excelente siempre que necesite descartar esos registros que no se repiten en ambas matrices. –

+5

Esto técnicamente no responde la pregunta. @OsvaldoM. quiere unirse basado en el valor de id, no por las claves. – Ray

0

bien, vamos a suppost sus matrices se denominan $ arr1 y $ arr2, usted puede hacer esto:

<?php 
$newarray = Array(); 
foreach ($arr1 as $element=>$value){ 
    $newarray = array_merge($arr1[$element],$arr2[$element]) 
} 
?> 
0

Como Ray notó en un comentario, la respuesta aceptada en realidad no responde la pregunta. No he podido encontrar una respuesta, así que creé la siguiente función de utilidad pequeña:

function array_merge_callback($array1, $array2, $predicate) { 
    $result = array(); 

    foreach ($array1 as $item1) { 
     foreach ($array2 as $item2) { 
      if ($predicate($item1, $item2)) { 
       $result[] = array_merge($item1, $item2); 
      } 
     } 
    } 

    return $result; 
} 

utilizarlo como sigue:

array_merge_callback($array1, $array2, function ($item1, $item2) { 
    return $item1['id'] == $item2['id']; 
}); 
0

tenga un buen uno a la fusión de las matrices como otros idiomas. Es porque php tiene elementos de matriz de numeración automática, y la fusión duplicará o reemplazará diferentes elementos por claves.

Ahora, ha cambiado.

// array_fork 
    public static function array_fork() { 
    $args = func_get_args(); 
    $result = array(); 
    foreach ($args as $arr) { 
     is_array($arr) || exit('[' . __METHOD__ . '] Each item must be an array.'); 
     foreach ($arr as $key => $val) { 
     if (is_array($val)) { 
      // recursion 
      !isset($result[$key]) && $result[$key] = array(); 
      $result[$key] = self::array_fork($result[$key], $arr[$key]); 
      continue; 
     } 
     if (is_numeric($key)) { 
      if (!in_array($arr[$key], $result)) 
      $result[] = $arr[$key]; 
     } else 
      $result[$key] = $arr[$key]; 
     } 
    } 
    return $result; 
    } 
0
function custom_array_merge(&$array1, &$array2) { 
    $result = Array(); 
    foreach ($array1 as $key_1 => &$value_1) { 
     // if($value['name']) 
     foreach ($array2 as $key_1 => $value_2) { 
      if($value_1['name'] == $value_2['name']) { 
       $result[] = array_merge($value_1,$value_2); 
      } 
     } 

    } 
    return $result; 
} 

// Pass $ matriz1, & $ matriz2 y cambiar los $ valor_2 [ 'nombre'] // nombre basado en el que u desea fusionar.

Cuestiones relacionadas