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?
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
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
)
Já olhei isso e não vi como isso pode ajudar a mesclar matrizes multidimensionais.Talvez você pudesse dar um exemplo.
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;
}