Maison >développement back-end >tutoriel php >Exemple de code pour spécifier le tri multi-champs pour l'exemple PHP multidimensionnel array_php
Cet article présente principalement l'exemple de code pour spécifier le tri multi-champs des tableaux multidimensionnels PHP. L'éditeur pense que c'est assez bon, je vais donc le partager avec vous maintenant et le donner comme référence. Suivons l'éditeur et jetons un coup d'œil.
Présentation de la méthode array_multisort
array_multisort — Triez plusieurs tableaux ou tableaux multidimensionnels Instructions dans son manuel PHP. Comme suit :
Copier le code Le code est le suivant :
bool array_multisort ( array &$arr [, Mixed $arg = SORT_ASC [, Mixed $arg = SORT_REGULAR [, Mixed $ ... ]]] )
Paramètres
arr
Un tableau à trier.
arg
Chacun des arguments suivants peut être un autre tableau ou un paramètre d'option d'indicateur de tri pour le tableau précédent : SORT_ASC, SORT_DESC, SORT_REGULAR, SORT_NUMERIC, SORT_STRING
…
. Arguments supplémentaires.
Implantez d'abord le tri d'un champ du tableau multidimensionnel spécifié
Ici, il est nécessaire de trier le tableau en fonction à l'un des champs. Les hypothèses du tableau sont les suivantes :
$array = array( 0=>array('id'=>8,'name'=>'Tom'), 1=>array('id'=>9,'name'=>'Peter'), 2=>array('id'=>5,'name'=>'Jack') );
Nous voulons trier en fonction de la valeur id de le tableau bidimensionnel. Le format du tableau converti est le suivant :
$array = array( 0=>array('id'=>5,'name'=>'Jack') 1=>array('id'=>8,'name'=>'Tom'), 2=>array('id'=>9,'name'=>'Peter') );
Pour terminer la conversion ci-dessus, vous devez utilisez la fonction array_multisort introduite ci-dessus, comme suit :
function sortArrByOneField(&$array, $field, $desc = false){ $fieldArr = array(); foreach ($array as $k => $v) { $fieldArr[$k] = $v[$field]; } $sort = $desc == false ? SORT_ASC : SORT_DESC; array_multisort($fieldArr, $sort, $array); }
Participe au tri dans le array_multisort entrant en enregistrant le champ $ de chaque tableau du tableau à trier dans le tableau d'un bit fieldArr. Les valeurs du tableau de champs sont les suivantes :
array(0=>8,1=>9,2=>5)
Après avoir passé array_multisort, cela équivaut à trier le Tableau unidimensionnel $field Reconstruisez ensuite le tableau entrant à trier en fonction des clés triées.
Implémentation du tri de tableaux multidimensionnels en spécifiant plusieurs champs
L'exemple ci-dessus explique comment implémenter le tri de tableaux multidimensionnels en spécifiant un champ, mais si vous le souhaitez Comment penser à spécifier plusieurs champs pour trier un tableau ?
Combien de champs y a-t-il ? 2, 3 ou plus, ce facteur incertain doit donc être éliminé.
Regardons d'abord les 2 options permettant de spécifier 2 champs de tri :
$arr = array( '0' => array( 'id' => 3, 'age' => 27 ), '1' => array( 'id' => 5, 'age' => 50 ), '2' => array( 'id' => 4, 'age' => 44 ), '3' => array( 'id' => 3, 'age' => 78 ) ); foreach ( $arr as $key => $row ){ $id[$key] = $row ['id']; $age[$key] = $row ['age']; } array_multisort($id, SORT_ASC, $age, SORT_DESC, $arr); print_r($arr); //result:Array([0]=>Array(['id']=>3 ['age']=>78) [1]=>Array(['id']=>3 ['age']=>27) [2]=>Array(['id']=>4 ['age']=>44) [3]=>Array(['id']=>5 ['age']=>50))
Refactorisez le code ci-dessus et utilisez la fonction func_get_args en PHP pour obtenir dynamiquement la valeur entrante, ce qui peut résoudre le problème du nombre incertain de plusieurs champs. L'implémentation est la suivante :
$array1 = array( 0=>array('id'=>8,'name'=>'Apple','age'=> 18), 1=>array('id'=>8,'name'=>'Bed','age'=>17), 2=>array('id'=>5,'name'=>'Cos','age'=>16), 3=>array('id'=>5,'name'=>'Cos','age'=>14) ); function sortArrByManyField(){ $args = func_get_args(); if(empty($args)){ return null; } $arr = array_shift($args); if(!is_array($arr)){ throw new Exception("第一个参数不为数组"); } foreach($args as $key => $field){ if(is_string($field)){ $temp = array(); foreach($arr as $index=> $val){ $temp[$index] = $val[$field]; } $args[$key] = $temp; } } $args[] = &$arr;//引用值 call_user_func_array('array_multisort',$args); return array_pop($args); } $arr = sortArrByManyField($array1,'id',SORT_ASC,'name',SORT_ASC,'age',SORT_DESC); print_r($arr);
Le résultat d'exécution est le suivant :
tableau (4) {
âge"]= >int(16)
; ["id "]=>int(8)
]=>int(17)
}
}
Ce qui précède représente l'intégralité du contenu de cet article. J'espère que cela sera utile à l'étude de tout le monde et j'espère que tout le monde soutiendra davantage le site Web chinois php.Articles qui pourraient vous intéresser :
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!