国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發(fā) > PHP > 正文

PHP使用array_multisort對多個數(shù)組或多維數(shù)組進(jìn)行排序

2024-05-04 23:28:58
字體:
供稿:網(wǎng)友
這篇文章主要介紹了PHP使用array_multisort對多個數(shù)組或多維數(shù)組進(jìn)行排序,需要的朋友可以參考下
 
 

PHP中array_multisort可以用來一次對多個數(shù)組進(jìn)行排序,或者根據(jù)某一維或多維對多維數(shù)組進(jìn)行排序。

關(guān)聯(lián)(string)鍵名保持不變,但數(shù)字鍵名會被重新索引。 
輸入數(shù)組被當(dāng)成一個表的列并以行來排序——這類似于 SQL 的 ORDER BY 子句的功能。第一個數(shù)組是要排序的主要數(shù)組。數(shù)組中的行(值)比較為相同的話就按照下一個輸入數(shù)組中相應(yīng)值的大小來排序,依此類推。——這句話是理解此函數(shù)用法的關(guān)鍵。

第一個參數(shù)必須是一個數(shù)組。接下來的每個參數(shù)可以是數(shù)組或者是下面列出的排序標(biāo)志。

排序順序標(biāo)志: 
■SORT_ASC - 按照上升順序排序 
■SORT_DESC - 按照下降順序排序

排序類型標(biāo)志: 
■SORT_REGULAR - 將項(xiàng)目按照通常方法比較 
■SORT_NUMERIC - 將項(xiàng)目按照數(shù)值比較 
■SORT_STRING - 將項(xiàng)目按照字符串比較

每個數(shù)組之后不能指定兩個同類的排序標(biāo)志。每個數(shù)組后指定的排序標(biāo)志僅對該數(shù)組有效 - 在此之前為默認(rèn)值 SORT_ASC 和 SORT_REGULAR。

看看兩個實(shí)際例子:

1、一次對多個數(shù)組進(jìn)行排序:

 

復(fù)制代碼代碼如下:

 $num1 = array(3, 5, 4, 3);
 $num2 = array(27, 50, 44, 78);
 array_multisort($num1, SORT_ASC, $num2, SORT_DESC);
 
 print_r($num1);
 print_r($num2);
 //result: Array ( [0] => 3 [1] => 3 [2] => 4 [3] => 5 ) Array ( [0] => 78 [1] => 27 [2] => 44 [3] => 50 ) 

 

2、對多維數(shù)組(以二位數(shù)組為例)進(jìn)行排序:

 

復(fù)制代碼代碼如下:

 $arr = array(
     '0' => array(
         'num1' => 3,
         'num2' => 27 
     ),
     '1' => array(
         'num1' => 5,
         'num2' => 50
     ),
     '2' => array(
         'num1' => 4,
         'num2' => 44
     ),
     '3' => array(
         'num1' => 3,
         'num2' => 78
     ) 
 );
 foreach ( $arr as $key => $row ){
     $num1[$key] = $row ['num1'];
     $num2[$key] = $row ['num2'];
 }
 array_multisort($num1, SORT_ASC, $num2, SORT_DESC, $arr);
 print_r($arr);
 //result:Array([0]=>Array([num1]=>3 [num2]=>78) [1]=>Array([num1]=>3 [num2]=>27) [2]=>Array([num1]=>4 [num2]=>44) [3]=>Array([num1]=>5 [num2]=>50))

 

總結(jié):

這里的重點(diǎn)就是,先把要排序的key存到一個一維數(shù)組中,然后就可以使用array_multisort()這個函數(shù),將數(shù)組按照key進(jìn)行排序了,當(dāng)然,這里的排序你完全可以不適用array_multisort()這個函數(shù),僅僅通過foreach遍歷也能達(dá)到這個效果,但是既然php開發(fā)者給我們提供了更好的辦法,我們就可以省去不必要的麻煩了。


發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 三都| 库尔勒市| 会同县| 乌兰县| 临泉县| 舒城县| 枣阳市| 阿鲁科尔沁旗| 武威市| 虞城县| 中西区| 乌拉特前旗| 汤原县| 菏泽市| 新龙县| 鄱阳县| 新余市| 泸溪县| 襄樊市| 乌苏市| 甘谷县| 来安县| 呼伦贝尔市| 安陆市| 顺义区| 凤庆县| 阜新市| 久治县| 兖州市| 岳阳县| 莎车县| 德惠市| 顺昌县| 广东省| 德化县| 宁夏| 苏尼特右旗| 浮梁县| 绥宁县| 六盘水市| 塔河县|