Pergunta

Tenho duas matrizes de animais (por exemplo).

$array = array(
    array(
        'id' => 1,
        'name' => 'Cat',
    ),
    array(
        'id' => 2,
        'name' => 'Mouse',
    )
);

$array2 = array(
    array(
        'id' => 2,
        'age' => 321,
    ),
    array(
        'id' => 1,
        'age' => 123,
    )
);

Como posso mesclar os dois arrays em um pelo ID?

Foi útil?

Solução

Isso faz o que Erik sugeriu (id no.como chave de array) e mescla valores em $array2 para $results.

$results = array();

foreach($array as $subarray)
{
    $results[$subarray['id']] = array('name' => $subarray['name']);
}

foreach($array2 as $subarray)
{
    if(array_key_exists($subarray['id'], $results))
    {
        // Loop through $subarray would go here if you have extra 
        $results[$subarray['id']]['age'] = $subarray['age'];
    }
}

Outras dicas

@Andy

http://se.php.net/array_merge

Esse foi o meu primeiro pensamento, mas não funciona muito bem - no entanto array_merge_recursivo pode funcionar - com preguiça de verificar agora.

Primeiro, por que você não usa o ID como índice (ou chave, na matriz de estilo de mapeamento que as matrizes php são)?

$array = array(
    1 => array(
        'name' => 'Cat',
    ),
    2 => array(
        'name' => 'Mouse',
    )
);

depois disso você terá que percorrer um array, executando array_merge nos itens do outro:

foreach($array2 as $key=>$value) {
  if(!is_array($array[$key])) $array[$key] = $value;
  else $array[$key] = array_merge($array[key], $value); 
}

Algo assim, pelo menos.Talvez haja uma solução melhor?

<?php
      $a = array('a' => '1', 'b' => array('t' => '4', 'g' => array('e' => '8')));
      $b = array('c' => '3', 'b' => array('0' => '4', 'g' => array('h' => '5', 'v' => '9')));
      $c = array_merge_recursive($a, $b);
      print_r($c);
?>

array_merge_recursive — Mescla dois ou mais arrays recursivamente

saídas:

        Array
(
    [a] => 1
    [b] => Array
        (
            [t] => 4
            [g] => Array
                (
                    [e] => 8
                    [h] => 5
                    [v] => 9
                )

            [0] => 4
        )

    [c] => 3
)

@Andy

Já olhei isso e não vi como isso pode ajudar a mesclar matrizes multidimensionais.Talvez você pudesse dar um exemplo.

@kevin

Provavelmente é isso que precisarei fazer, pois acho que o código abaixo será muito lento.O código real é um pouco diferente porque estou usando ADOdb (e ODBC para a outra consulta), mas farei funcionar e postarei minha própria resposta.

Isso funciona, mas acho que será muito lento, pois passa sempre pelo segundo loop:

foreach($array as &$animal)
{
    foreach($array2 as $animal2)
    {
        if($animal['id'] === $animal2['id'])
        {
            $animal = array_merge($animal, $animal2);
            break;
        }
    }
}
foreach ($array as $a)
    $new_array[$a['id']]['name'] = $a['name'];

foreach ($array2 as $a)
    $new_array[$a['id']]['age'] = $a['age'];

e este é o resultado:

    [1] => Array
        (
            [name] => Cat
            [age] => 123
        )

    [2] => Array
        (
            [name] => Mouse
            [age] => 321
        )
<?php
$array1 = array("color" => "red", 2, 4);
$array2 = array("a", "b", "color" => "green", "shape" => "trapezoid", 4);
$result = array_merge($array1, $array2);
print_r($result);
?>

Com o PHP 5.3 você pode fazer esse tipo de mesclagem com array_replace_recursive()

http://www.php.net/manual/en/function.array-replace-recursive.php

Sua matriz resultante deve ser semelhante a:

Array (
    [0] => Array
        (
            [id] => 2
            [name] => Cat
            [age] => 321
        )

    [1] => Array
        (
            [id] => 1
            [name] => Mouse
            [age] => 123
        )
)

Qual é o que eu acho que você queria como resultado.

Eu preferiria array_splice sobre array_merge devido a seus problemas de desempenho, minha solução seria:

<?php 
array_splice($array1,count($array1),0,$array2);
?>
$new = array();
foreach ($array as $arr) {
    $match = false;
    foreach ($array2 as $arr2) {
        if ($arr['id'] == $arr2['id']) {
           $match = true;
           $new[] = array_merge($arr, $arr2);
           break;
        }
    }
    if ( !$match ) $new[] = $arr;
}
Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow
scroll top