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)行排序:
2、對多維數(shù)組(以二位數(shù)組為例)進(jìn)行排序:
總結(jié):
這里的重點(diǎn)就是,先把要排序的key存到一個一維數(shù)組中,然后就可以使用array_multisort()這個函數(shù),將數(shù)組按照key進(jìn)行排序了,當(dāng)然,這里的排序你完全可以不適用array_multisort()這個函數(shù),僅僅通過foreach遍歷也能達(dá)到這個效果,但是既然php開發(fā)者給我們提供了更好的辦法,我們就可以省去不必要的麻煩了。
新聞熱點(diǎn)
疑難解答