Domanda
Ho due matrici di animali (per esempio).
$array = array(
array(
'id' => 1,
'name' => 'Cat',
),
array(
'id' => 2,
'name' => 'Mouse',
)
);
$array2 = array(
array(
'id' => 2,
'age' => 321,
),
array(
'id' => 1,
'age' => 123,
)
);
Come posso unire i due array in uno tramite l'ID?
Soluzione
Questo fa quello che ha suggerito Erik (id no.come chiave di array) e unisce vlaues in $array2
A $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'];
}
}
Altri suggerimenti
@Andy
Questo è stato il mio primo pensiero, ma non funziona del tutto, comunque array_merge_recursive potrebbe funzionare: sono troppo pigro per controllare in questo momento.
Prima di tutto, perché non usi l'ID come indice (o chiave, nell'array in stile mappatura che gli array php sono imo)?
$array = array(
1 => array(
'name' => 'Cat',
),
2 => array(
'name' => 'Mouse',
)
);
dopodiché dovrai eseguire il foreach attraverso un array, eseguendo array_merge sugli elementi dell'altro:
foreach($array2 as $key=>$value) {
if(!is_array($array[$key])) $array[$key] = $value;
else $array[$key] = array_merge($array[key], $value);
}
Qualcosa del genere almeno.Forse c'è una soluzione migliore?
<?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 — Unisce due o più array in modo ricorsivo
uscite:
Array
(
[a] => 1
[b] => Array
(
[t] => 4
[g] => Array
(
[e] => 8
[h] => 5
[v] => 9
)
[0] => 4
)
[c] => 3
)
L'ho già guardato e non ho visto come possa aiutare a unire array multidimensionali.Forse potresti fare un esempio.
Questo è probabilmente ciò che dovrò fare poiché penso che il codice seguente sarà molto lento.Il codice effettivo è leggermente diverso perché sto utilizzando ADOdb (e ODBC per l'altra query) ma lo farò funzionare e pubblicherò la mia risposta.
Funziona, tuttavia penso che sarà molto lento poiché esegue ogni volta il secondo ciclo:
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 questo è il risultato:
[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);
?>
Con PHP 5.3 puoi eseguire questo tipo di unione con array_replace_recursive()
http://www.php.net/manual/en/function.array-replace-recursive.php
L'array risultante dovrebbe assomigliare a:
Array (
[0] => Array
(
[id] => 2
[name] => Cat
[age] => 321
)
[1] => Array
(
[id] => 1
[name] => Mouse
[age] => 123
)
)
Questo è quello che penso tu volessi come risultato.
Preferirei array_splice
Sopra array_merge
a causa dei suoi problemi di prestazioni, la mia soluzione sarebbe:
<?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;
}