国产探花免费观看_亚洲丰满少妇自慰呻吟_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ā)表
主站蜘蛛池模板: 林西县| 双流县| 丰台区| 鹿邑县| 彭州市| 湖北省| 高安市| 桦甸市| 招远市| 新闻| 福建省| 治多县| 连南| 凉城县| 平阴县| 锡林郭勒盟| 金秀| 太和县| 彩票| 岫岩| 邛崃市| 林甸县| 若羌县| 丰顺县| 广宗县| 阿图什市| 霞浦县| 新田县| 内江市| 水富县| 西乌珠穆沁旗| 五家渠市| 汉阴县| 陇西县| 小金县| 嵊泗县| 喜德县| 乌兰浩特市| 昭通市| 武川县| 公主岭市|