web-dev-qa-db-fra.com

Fusion de tableaux avec les mêmes clés

Dans un logiciel, je fusionne deux tableaux avec array_merge une fonction. Mais je dois ajouter le même tableau (avec les mêmes clés, bien sûr) à un tableau existant.

Le problème:

 $A = array('a' => 1, 'b' => 2, 'c' => 3);
 $B = array('c' => 4, 'd'=> 5);

 array_merge($A, $B);

 // result
 [a] => 1 [b] => 2 [c] => 4 [d] => 5

Comme tu vois, 'c' => 3 Est manqué.

Alors, comment puis-je fusionner tous avec les mêmes clés?

40
beytarovski

Vous devez utiliser array_merge_recursive au lieu de array_merge. Bien sûr, il ne peut y avoir qu'une seule clé égale à 'c' dans le tableau, mais la valeur associée sera un tableau contenant à la fois 3 et 4.

Voir en action .

49
Jon

Essayez avec array_merge_recursive

$A = array('a' => 1, 'b' => 2, 'c' => 3);
$B = array('c' => 4, 'd'=> 5);
$c = array_merge_recursive($A,$B);

echo "<pre>";
print_r($c);
echo "</pre>";

reviendra

Array
(
    [a] => 1
    [b] => 2
    [c] => Array
        (
            [0] => 3
            [1] => 4
        )

    [d] => 5
)
23
diEcho
$arr1 = array(
   "0" => array("fid" => 1, "tid" => 1, "name" => "Melon"),
   "1" => array("fid" => 1, "tid" => 4, "name" => "Tansuozhe"),
   "2" => array("fid" => 1, "tid" => 6, "name" => "Chao"),
   "3" => array("fid" => 1, "tid" => 7, "name" => "Xi"),
   "4" => array("fid" => 2, "tid" => 9, "name" => "Xigua")
);

si vous souhaitez convertir ce tableau comme suit:

$arr2 = array(
   "0" => array(
          "0" => array("fid" => 1, "tid" => 1, "name" => "Melon"),
          "1" => array("fid" => 1, "tid" => 4, "name" => "Tansuozhe"),
          "2" => array("fid" => 1, "tid" => 6, "name" => "Chao"),
          "3" => array("fid" => 1, "tid" => 7, "name" => "Xi")
    ),

    "1" => array(
          "0" =>array("fid" => 2, "tid" => 9, "name" => "Xigua")
     )
);

donc, ma réponse sera comme ceci:

$outer_array = array();
$unique_array = array();
foreach($arr1 as $key => $value)
{
    $inner_array = array();

    $fid_value = $value['fid'];
    if(!in_array($value['fid'], $unique_array))
    {
            array_Push($unique_array, $fid_value);
            unset($value['fid']);
            array_Push($inner_array, $value);
            $outer_array[$fid_value] = $inner_array;


    }else{
            unset($value['fid']);
            array_Push($outer_array[$fid_value], $value);

    }
}
var_dump(array_values($outer_array));

espérons que cette réponse aidera quelqu'un à un moment donné.

4
Melon
 $A = array('a' => 1, 'b' => 2, 'c' => 3);
 $B = array('c' => 4, 'd'=> 5);
 $C = array_merge_recursive($A, $B);
 $aWhere = array();
 foreach ($C as $k=>$v) {

    if (is_array($v)) {
        $aWhere[] = $k . ' in ('.implode(', ',$v).')';
    }
    else {
        $aWhere[] = $k . ' = ' . $v;
    }
 }
 $where = implode(' AND ', $aWhere);
 echo $where;
2
Nemoden

Je viens d'écrire cette fonction, elle devrait faire l'affaire pour vous, mais elle reste jointe

public function mergePerKey($array1,$array2)
    {
        $mergedArray = [];

        foreach ($array1 as $key => $value) 
        {
            if(isset($array2[$key]))
             {
               $mergedArray[$value] = null;

               continue;
             }
            $mergedArray[$value] = $array2[$key];
        }

        return $mergedArray;
    }
2
Kamaro Lambert

Deux entrées dans un tableau ne peuvent pas partager une clé, vous devrez changer la clé du doublon

1
Mild Fuzz

Essaye ça:

$array_one = $_POST['ratio_type'];
$array_two = $_POST['ratio_type'];
$array_three = $_POST['ratio_type'];
$array_four = $_POST['ratio_type'];
$array_five = $_POST['ratio_type'];
$array_six = $_POST['ratio_type'];
$array_seven = $_POST['ratio_type'];
$array_eight = $_POST['ratio_type'];

$all_array_elements = array_merge_recursive(
    $array_one,
    $array_two,
    $array_three,
    $aray_four, 
    $array_five,
    $array_six,
    $array_seven,
    $array_eight
);

print_r($all_array_elements, 1);

foreach ($all_array_elements as $key => $value) {          
    echo $key.'-'.$value;            
}
1
Radhason