fusionnant des tableaux associatifs et en ajoutant des colonnes manquantes avec des valeurs par défaut
Fusionner plusieurs tableaux associatifs tout en préservant toutes les clés uniques et en ajoutant des colonnes manquantes avec des valeurs par défaut peut être réalisée en utilisant diverses techniques. Explorons deux méthodes pour accomplir ceci:
Méthode 1: Utilisation de Array_merge et récursiveiterationiterator
$a = array('a' => 'some value', 'b' => 'some value', 'c' => 'some value');
$b = array('a' => 'another value', 'd' => 'another value', 'e' => 'another value', 'f' => 'another value');
$c = array('b' => 'some more value', 'x' => 'some more value', 'y' => 'some more value', 'z' => 'some more value');
$d = array($a, $b, $c);
$keys = array();
foreach (new RecursiveIteratorIterator(new RecursiveArrayIterator($d)) as $key => $val) {
$keys[$key] = '';
}
$data = array();
foreach ($d as $values) {
$data[] = array_merge($keys, $values);
}
echo '';
print_r($data);
Cette approche utilise d'abord RecursiveIteratoriterator en conjonction avec array_merge pour identifier toutes les touches uniques dans chaque tableau associatif. Il initialise ensuite un tableau vide ($ clés) avec les touches identifiées. Par la suite, il itère via chaque tableau de $ d, fusionnant le tableau de touches $ avec les valeurs de chaque tableau pour obtenir le format souhaité.
Méthode 2: Utilisation de Array_Combine et Array_Map
$keys = array_keys(call_user_func_array('array_merge', $d));
$key_pair = array_combine($keys, array_fill(0, count($keys), null));
$values = array_map(function ($e) use ($key_pair) {
return array_merge($key_pair, $e);
}, $d);
Cette approche utilise array_keys pour déterminer l'union de toutes les clés uniques dans le tableau fusionné. Il utilise ensuite Array_Combine pour créer une paire de valeurs de clé où les clés sont les touches uniques, et les valeurs sont nulles. Enfin, Array_Map est habitué à itérer à travers $ D, fusionnant la paire de valeurs clés ($ key_pair) avec chaque tableau associatif dans $ d, résultant en le format souhaité.
Clause de non-responsabilité: Toutes les ressources fournies proviennent en partie d'Internet. En cas de violation de vos droits d'auteur ou d'autres droits et intérêts, veuillez expliquer les raisons détaillées et fournir une preuve du droit d'auteur ou des droits et intérêts, puis l'envoyer à l'adresse e-mail : [email protected]. Nous nous en occuperons pour vous dans les plus brefs délais.
Copyright© 2022 湘ICP备2022001581号-3