Regroupement de lignes de tableaux associatifs par valeur de colonne
En programmation, vous pouvez rencontrer des situations dans lesquelles vous devez réorganiser les données stockées dans des tableaux associatifs. Une tâche courante consiste à regrouper les lignes du tableau en fonction d'une valeur de colonne spécifique tout en préservant les clés de premier niveau d'origine.
Considérez le tableau associatif suivant de tableaux associatifs appelé $old_arr :
[ 'a' => ['id' => 20, 'name' => 'chimpanzee'], 'b' => ['id' => 40, 'name' => 'meeting'], 'c' => ['id' => 20, 'name' => 'dynasty'], 'd' => ['id' => 50, 'name' => 'chocolate'], 'e' => ['id' => 10, 'name' => 'bananas'], 'f' => ['id' => 50, 'name' => 'fantasy'], 'g' => ['id' => 50, 'name' => 'football'] ]
L'objectif est de créer un nouveau tableau, $arr, où les lignes sont regroupées en fonction du champ id. Le tableau résultant devrait ressembler à ceci :
array ( 10 => array ( e => array ( id = 10, name = bananas ) ) 20 => array ( a => array ( id = 20, name = chimpanzee ) c => array ( id = 20, name = dynasty ) ) 40 => array ( b => array ( id = 40, name = meeting ) ) 50 => array ( d => array ( id = 50, name = chocolate ) f => array ( id = 50, name = fantasy ) g => array ( id = 50, name = football ) ) )
Pour y parvenir, vous pouvez suivre ces étapes :
Le code PHP fourni suit cette approche pour générer le résultat souhaité :
$arr = array(); foreach ($old_arr as $key => $item) { $arr[$item['id']][$key] = $item; } ksort($arr, SORT_NUMERIC);
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