Объединить два ассоциативных массива одним ключом - PullRequest
0 голосов
/ 29 мая 2018

У меня есть два ассоциативных массива, имеющих одно общее значение, например

ARRAY 1(
  [0]=>
  array(2) {
    ["ID"]=> "AAAA"
    ["Name"]=> "Apple"
  }
  [1]=>
  array(2) {
    ["ID"]=> "BBBB"
    ["Name"]=> "Avocado"
  }
  [3]=>
  array(2) {
    ["ID"]=> "CCCC"
    ["Name"]=> "Banana"
  }
)



Array2 (
  [0]=>
  array(4) {
    ["ID"]=> "AAAA"
    ["Taste"]=> "Yumi"
    ["Location"]=> "France"
    ["Price"]=> "Cheap"
  }
  [1]=>
  array(4) {
    ["ID"]=> "CCCC"
    ["Taste"]=> "Yumi"
    ["Location"]=> "Africa"
    ["Price"]=> "Cheap"
  }
  [3]=>
  array(4) {
    ["ID"]=> "BBBB"
    ["Taste"]=> "Yumi"
    ["Location"]=> "America"
    ["Price"]=> "Expansive"
  }
  [3]=>
  array(4) {
    ["ID"]=> "HZGA"
    ["Taste"]=> "Berk"
    ["Location"]=> "Moon"
    ["Price"]=> "Expansive"
  }    

)

Я хотел бы объединить их по их идентификатору.Простое объединение невозможно, потому что они не отсортированы, имеют значения более 40 000 + и имеют разный размер.

Я планировал использовать двойной foreach и создать третий массив, в котором был указан идентификатор.общие, я отбросил идею.Поскольку анализ 40 000 значений в первом массиве для каждого из 40 000 значений из второго массива занимает слишком много времени.

Есть ли какое-то решение?Я бы хотел, чтобы в финале все выглядело так:

ArrayFinal (
  [0]=>
  array(4) {
    ["ID"]=> "AAAA"
    ["Name"]=> "Apple"
    ["Taste"]=> "Yumi"
    ["Location"]=> "France"
    ["Price"]=> "Cheap"
  }
  [1]=>
  array(4) {
    ["ID"]=> "CCCC"
    ["Name"]=> "Banana"
    ["Taste"]=> "Yumi"
    ["Location"]=> "Africa"
    ["Price"]=> "Cheap"
  }
  [3]=>
  array(4) {
    ["ID"]=> "BBBB"
    ["Name"]=> "Avocado"
    ["Taste"]=> "Yumi"
    ["Location"]=> "America"
    ["Price"]=> "Expansive"
  }
)

Ответы [ 2 ]

0 голосов
/ 29 мая 2018

Вы не можете избежать зацикливания.Но foreach довольно быстрый.Протестировано на массиве 50.000 и заняло 0,04 секунды.

Что будет сделано:

  • создать массив TMP
  • получить значения KEY и ID изARRAY1
  • поместите их как ключ 'ID' => в массиве TMP
  • цикл ARRAY2, получите идентификатор
  • , найдите соответствующий идентификатор в TMP
  • получить ключ от ARRAY1
  • объединить ARRAY1 и ARRAY2

В итоге у ARRAY1 будут данные из ARRAY2

$ar1=[...]; //original array 1
$ar2=[...]; //original array 2

// get ID=> key pairs
$kv=[];
foreach($ar1 as $k => $v){
    $kv[ $v['id'] ] = $k;
    }

// loop ARRAY2
foreach($ar2 as $k => $v){
    if( array_key_exists( $v['id'] , $kv ) ){
        $ar1[ $kv[$v['id']] ] = array_merge( $ar1[$kv[$v['id']]] , $ar2[$k] );
        }
    }
0 голосов
/ 29 мая 2018

https://eval.in/1011901

 <?php 

$a = [['ID'=> 'TOTO'], ['ID' => 'TATA']];
$b = [['ID' => 'TATA', 'RA' => 'T'], ['ID' => 'TOTO', 'COUCOU' => 2]];

$final = [];

foreach($a as $c){
  if(!isset($final[$c['ID']])){
    $final[$c['ID']] = $c;
  }else{
    $final[$c['ID']] += $c;
  }
}
foreach($b as $c){
  if(!isset($final[$c['ID']])){
    $final[$c['ID']] = $c;
  }else{
    $final[$c['ID']] += $c;
  }
}
var_dump(array_values($final));

ВЫХОД

array(2) {
  [0]=>
  array(2) {
    ["ID"]=>
    string(4) "TOTO"
    ["COUCOU"]=>
    int(2)
  }
  [1]=>
  array(2) {
    ["ID"]=>
    string(4) "TATA"
    ["RA"]=>
    string(1) "T"
  }
}
...