web-dev-qa-db-fra.com

PHP: fusionner deux tableaux tout en conservant les clés au lieu de réindexer?

Comment puis-je fusionner deux tableaux (un avec des paires chaîne => et des paires avec des paires int =>) tout en conservant les clés chaîne/int? Aucune d'entre elles ne se chevauchera jamais (car l'une n'a que des chaînes et l'autre des entiers).

Voici mon code actuel (qui ne fonctionne pas, car array_merge réindexe le tableau avec des clés entières):

// get all id vars by combining the static and dynamic
$staticIdentifications = array(
 Users::userID => "USERID",
 Users::username => "USERNAME"
);
// get the dynamic vars, formatted: varID => varName
$companyVarIdentifications = CompanyVars::getIdentificationVarsFriendly($_SESSION['companyID']);
// merge the static and dynamic vars (*** BUT KEEP THE INT INDICES ***)
$idVars = array_merge($staticIdentifications, $companyVarIdentifications);
218
Garrett

Vous pouvez simplement "ajouter" les tableaux:

>> $a = array(1, 2, 3);
array (
  0 => 1,
  1 => 2,
  2 => 3,
)
>> $b = array("a" => 1, "b" => 2, "c" => 3)
array (
  'a' => 1,
  'b' => 2,
  'c' => 3,
)
>> $a + $b
array (
  0 => 1,
  1 => 2,
  2 => 3,
  'a' => 1,
  'b' => 2,
  'c' => 3,
)
487
SirDarius

Considérant que vous avez 

$replaced = array('1' => 'value1', '4' => 'value4');
$replacement = array('4' => 'value2', '6' => 'value3');

Faire $merge = $replacement + $replaced; affichera:

Array('1' => 'value1', '4' => 'value2', '6' => 'value3');

Le premier tableau de sum aura des valeurs dans la sortie finale.

Faire $merge = $replaced + $replacement; affichera:

Array('1' => 'value1', '4' => 'value4', '6' => 'value3');
49
CRK

Bien que cette question soit assez ancienne, je souhaite simplement ajouter une autre possibilité de fusion tout en conservant les clés.

Outre l'ajout de clés/valeurs aux tableaux existants à l'aide du signe +, vous pouvez créer un array_replace.

$a = array('foo' => 'bar', 'some' => 'string');
$b = array(42 => 'answer to the life and everything', 1337 => 'leet');

$merged = array_replace($a, $b);

Les mêmes clés seront écrasées par ce dernier tableau.
Il existe également un array_replace_recursive, qui le fait également pour les sous-tableaux.

Exemple en direct sur 3v4l.org

12
danopz

Deux tableaux peuvent être facilement ajoutés ou unis sans modifier leur indexation d'origine par l'opérateur + . Ce sera très utile dans les listes déroulantes laravel et codeigniter. 

 $empty_option = array(
         ''=>'Select Option'
          );

 $option_list = array(
          1=>'Red',
          2=>'White',
          3=>'Green',
         );

  $arr_option = $empty_option + $option_list;

La sortie sera:

$arr_option = array(
   ''=>'Select Option'
   1=>'Red',
   2=>'White',
   3=>'Green',
 );
1
amba patel

Essayez les fonctions array_replace_recursive ou array_replace

$a = array('userID' => 1, 'username'=> 2);
array (
  userID => 1,
  username => 2
)
$b = array('userID' => 1, 'companyID' => 3);
array (
  'userID' => 1,
  'companyID' => 3
)
$c = array_replace_recursive($a,$b);
array (
  userID => 1,
  username => 2,
  companyID => 3
)

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

0
user3704337