Dans l'article précédent "PHP Dans Array Learning : Comment intercepter des fragments d'éléments (deux méthodes) ", nous avons présenté comment intercepter des tableaux et renvoyer des fragments d'éléments de tableau partiels. Deux méthodes. Cette fois, nous continuons l'étude des tableaux PHP et parlons de la méthode de tri des éléments d'un tableau bidimensionnel. Les amis intéressés peuvent apprendre. En savoir plus~
→ Recommandations associées : 《Résumé de la série d'apprentissage des tableaux PHP (mis à jour en permanence~)》
Avant, nous avons découvert plusieurs méthodes de tri des tableaux unidimensionnels, et nous savons que PHP a de nombreuses méthodes intégrées fonctions pour implémenter le tri décroissant et ascendant des tableaux unidimensionnels. Alors, les tableaux bidimensionnels ont-ils également des fonctions intégrées pour implémenter le tri ?
La réponse est : Oui ! PHP a une fonction intégrée array_multisort()
qui peut être utilisée pour trier des tableaux bidimensionnels. Ci-dessous, nous vous présentons deux méthodes de tri de tableaux bidimensionnels à l'aide de la fonction array_multisort(). array_multisort()
函数可实现二维数组的排序。下面我们给大家介绍两种利用array_multisort()函数对二维数组进行排序的方法。
方法1:foreach循环 + array_multisort()函数
<?php $data = array( array( 'id' => 5698, 'first_name' => 'Bill', 'last_name' => 'Gates', ), array( 'id' => 3809, 'first_name' => 'Mark', 'last_name' => 'Zuckerberg', ), array( 'id' => 4767, 'first_name' => 'Steve', 'last_name' => 'Aobs', ) ); // 取得列的列表 foreach ($data as $key => $row) { $ID[$key] = $row['id']; $FirstName[$key] = $row['first_name']; $LastName[$key] = $row['last_name']; } array_multisort($ID, SORT_ASC, $data); var_dump($data); ?>
分析一下代码:
使用foreach循环将同一字段的数据放在一起,使用var_dump($ID)
、var_dump($FirstName)
、var_dump($LastName)
输出各个字段数据试试:
使用array_multisort($ID, SORT_ASC, $data)
根据二维数组$data中 “id
”那一列字段进行升序排序。
因此输出结果:
而如果想要根据id降序排列,只要将该函数第二个参数设置为SORT_DESC
即可:
array_multisort($ID, SORT_DESC, $data);
输出结果:
如果想要根据last_name进行排序,只要将该函数第一个参数设置为$LastName数组即可
array_multisort($LastName, SORT_DESC, $data);
输出结果:
下面我们来了解一下array_multisort()函数:
array_multisort() 函数返回一个排序数组。用户可以输入一个或多个数组,该函数会先对第一个数组进行排序,接着是其他数组,如果两个或多个值相同,它将对下一个数组进行排序。语法如下:
array_multisort(array1,sorting order,sorting type,array2,array3...)
方法2:array_column()函数+array_multisort()函数
在方法1中,我们是利用foreach循环来获取同一字段的数据,这有点复杂。其实,可以使用array_column()函数来实现这一操作。array_column()函数可以返回输入数组中某个单一列的值。
<?php $data = array( array( 'id' => 5698, 'first_name' => 'Bill', 'last_name' => 'Gates', ), array( 'id' => 3809, 'first_name' => 'Mark', 'last_name' => 'Zuckerberg', ), array( 'id' => 4767, 'first_name' => 'Steve', 'last_name' => 'Aobs', ) ); //根据字段id对数组$data进行升序排列 $key = array_column($data,'id'); array_multisort($key,SORT_ASC,$data); var_dump($data); ?>
输出结果:
想要根据哪个字段来排序就将array_column($data,'id')
Méthode 1 : boucle foreach + fonction array_multisort()
$key = array_column($data,'first_name'); array_multisort($key,SORT_DESC,$data);
Analysez le code :
Utilisez la boucle foreach pour Rassemblez les données du même champ et utilisez var_dump($ID)
, var_dump($FirstName)
, var_dump($LastName)
pour afficher chaque champ Essayez les données :
array_multisort($ID, SORT_ASC, $data)
pour effectuer un ordre croissant en fonction du champ de la colonne "id
" dans le tableau bidimensionnel $data Trier. Et si vous souhaitez trier par identifiant par ordre décroissant, définissez simplement le deuxième paramètre de la fonction sur SORT_DESC
:
array_column(array,column_key,index_key);
Si vous souhaitez trier en fonction du nom de famille, définissez simplement le premier paramètre de la fonction sur le tableau $LastNamerrreeeRésultat de sortie :
🎜🎜🎜Jetons un coup d'oeil à la fonction array_multisort() : 🎜🎜🎜array_multisort() La fonction renvoie un tableau trié . L'utilisateur peut saisir un ou plusieurs tableaux et la fonction triera le premier tableau, puis les autres tableaux, et si deux ou plusieurs valeurs sont identiques, elle triera le tableau suivant. La syntaxe est la suivante : 🎜rrreee🎜🎜🎜Méthode 2 : fonction array_column() + fonction array_multisort()🎜🎜Dans la méthode 1, on utilise une boucle foreach pour obtenir les données du même champ, ce qui est un peu compliqué . En fait, vous pouvez utiliser la fonction array_column() pour réaliser cette opération. La fonction array_column() peut renvoyer la valeur d'une seule colonne du tableau d'entrée. 🎜rrreee🎜Résultat de sortie : 🎜🎜🎜🎜Si vous souhaitez trier par quel champ, remplacez simplement le deuxième paramètre de la fonctionarray_column($data,'id')
par ce champ (valeur clé). Par exemple, si vous souhaitez trier par ordre décroissant en fonction du champ « prénom », vous pouvez : 🎜🎜rrreee🎜 Résultat de sortie : 🎜🎜🎜🎜🎜 Jetons un coup d'œil à la fonction array_column() : 🎜🎜array_column() renvoie une seule colonne dans la valeur du tableau d'entrée. Le format de syntaxe est : 🎜rrreee🎜🎜🎜🎜Valeur de retour : renvoie un tableau, la valeur du tableau est la valeur d'une seule colonne dans le tableau d'entrée. 🎜🎜D'accord, c'est tout. Si vous voulez savoir autre chose, vous pouvez cliquer ici. → →🎜Tutoriel vidéo php🎜🎜🎜Enfin, je recommande un tutoriel vidéo gratuit sur les tableaux PHP : 🎜Explication vidéo de la fonction tableau de fonctions PHP🎜, venez apprendre ! 🎜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!