Maison >développement back-end >tutoriel php >Analyse approfondie de la fonction PHP array_multisort()
1. Regardons d’abord la situation la plus simple. Il existe deux tableaux :
$arr1 = array(1,9,5);
$arr2 = array(6,2,4);
array_multisort($arr1,$arr2);
print_r($arr1); //L'ordre obtenu est 1,5,9
print_r($arr2); //L'ordre obtenu est 6,4,2
J'estime que les valeursde les deux tableaux sont les mêmes du début à la fin. En conséquence : 1 correspond à 6, 9 correspond à 2 et 5 correspond à 4.
Ajoutons un tableau supplémentaire et voyons ce qui se passe :
$arr1 = array(1,9,5);
$arr2 = array(6,2,4);
$arr3 = array (3,7,8);
array_multisort($arr1,$arr2,$arr3);
En regardant les résultats, 1 correspond à 6 et 3 du début à la fin, et il en va de même pour les autres éléments . Cette correspondance est ce que le manuel appelle « préserver l'association de nom de clé d'origine pendant le tri ».
En outre, vous pouvez également considérer chaque tableau comme une colonne dans une table de base de données. Le 1,6,3 correspondant est une ligne de données et 9,2,7 est une autre ligne de données. . .
array_multisort triera d'abord par le premier tableau (imaginez comme une colonne), et si les valeurs du premier tableau (colonne) sont les mêmes, il sera trié par le deuxième tableau (colonne).
Vous pouvez utiliser le programme suivant pour tester :
$arr1 = array(1,9,5,9);
$arr2 = array(6,2,4,1);
$ arr3 = array(3,7,8,0);
array_multisort($arr1,$arr2,$arr3);
Vous pouvez imaginer que le résultat de $arr3 ici est (3,8,0,7 ).
2. Ensuite, nous expliquerons les paramètres de array_multisort. Les paramètres de cette fonction sont très flexibles. Le cas le plus simple consiste à utiliser 1 ou n tableaux comme paramètres comme indiqué ci-dessus. Il convient de noter que le nombre d'éléments dans chaque tableau doit être le même, sinon un avertissement entraînera l'échec du tri.
Comme ceci array_multisort($arr1,$arr2,$arr3); La valeur par défaut est que tous les tableaux sont triés par ordre croissant. Si vous souhaitez trier $arr2 par ordre décroissant et le comparer sous forme de chaîne, vous devez écrire. :
array_multisort( $arr1, $arr2, SORT_DESC, SORT_STRING, $arr3);
Chaque tableau peut être suivi d'un indicateur d'ordre de tri ou d'un indicateur de type de tri, ou les deux indicateurs peuvent apparaître en même temps. Mais un seul indicateur de tri de chaque type peut apparaître après chaque tableau.
Les détails sont les suivants :
Drapeaux d'ordre de tri :
SORT_ASC - Trier les éléments par ordre croissant (par défaut)
SORT_DESC - Trier les éléments par ordre décroissant
Indicateurs de type de tri :
SORT_REGULAR - Trier les éléments dans l'ordre normal Comparaison de méthodes (par défaut)
SORT_NUMERIC - Comparer les éléments en fonction de valeurs numériques
SORT_STRING - Comparer les éléments en fonction de chaînes
3. Enfin, quelle est la fonction réelle de array_multisort ?
Nous avons généralement des tableaux multidimensionnels qui doivent être triés :
$guys = Array ( [0] => Array ( [name] => jake [score] => 80 [grade] => A ) [1] => Array ( [name] => jin [score] => 70 [grade] => A ) [2] => Array ( [name] => john [score] => 80 [grade] => A ) [3] => Array ( [name] => ben [score] => 20 [grade] => B ) )
Par exemple, nous voulons trier par notes dans l'ordre inverse, et si les notes sont les mêmes, trier par nom par ordre croissant.
À ce stade, nous devons créer deux tableaux supplémentaires selon l'ordre de $guys :
$scores = array(80,70,80,20);
$names = array('jake', ' jin','john','ben');
Alors
array_multisort($scores, SORT_DESC, $names, $guys); C'est tout
Est-ce que ça peut être plus flexible, je veux trier chaque ? time Avons-nous besoin de tableaux supplémentaires ?
En fait, il a été bien encapsulé dans la classe helper_array de qeephp. Voici ses deux méthodes. Ceux qui en ont besoin peuvent le modifier eux-mêmes :
/** * 根据指定的键对数组排序 * * 用法: * @code php * $rows = array( *array('id' => 1, 'value' => '1-1', 'parent' => 1), *array('id' => 2, 'value' => '2-1', 'parent' => 1), *array('id' => 3, 'value' => '3-1', 'parent' => 1), *array('id' => 4, 'value' => '4-1', 'parent' => 2), *array('id' => 5, 'value' => '5-1', 'parent' => 2), *array('id' => 6, 'value' => '6-1', 'parent' => 3), * ); * * $rows = Helper_Array::sortByCol($rows, 'id', SORT_DESC); * dump($rows); * // 输出结果为: * // array( * // array('id' => 6, 'value' => '6-1', 'parent' => 3), * // array('id' => 5, 'value' => '5-1', 'parent' => 2), * // array('id' => 4, 'value' => '4-1', 'parent' => 2), * // array('id' => 3, 'value' => '3-1', 'parent' => 1), * // array('id' => 2, 'value' => '2-1', 'parent' => 1), * // array('id' => 1, 'value' => '1-1', 'parent' => 1), * // ) * @endcode * * @param array $array 要排序的数组 * @param string $keyname 排序的键 * @param int $dir 排序方向 * * @return array 排序后的数组 */ static function sortByCol($array, $keyname, $dir = SORT_ASC) { return self::sortByMultiCols($array, array($keyname => $dir)); } /** * 将一个二维数组按照多个列进行排序,类似 SQL 语句中的 ORDER BY * * 用法: * @code php * $rows = Helper_Array::sortByMultiCols($rows, array( *'parent' => SORT_ASC, *'name' => SORT_DESC, * )); * @endcode * * @param array $rowset 要排序的数组 * @param array $args 排序的键 * * @return array 排序后的数组 */ static function sortByMultiCols($rowset, $args) { $sortArray = array(); $sortRule = ''; foreach ($args as $sortField => $sortDir) { foreach ($rowset as $offset => $row) { $sortArray[$sortField][$offset] = $row[$sortField]; } $sortRule .= '$sortArray[\'' . $sortField . '\'], ' . $sortDir . ', '; } if (empty($sortArray) || empty($sortRule)) { return $rowset; } eval('array_multisort(' . $sortRule . '$rowset);'); return $rowset; }
Plus de PHP array_multisort() Pour in-. analyse approfondie des fonctions, veuillez faire attention au site Web PHP chinois !