詳解PHP 二維數(shù)組排序保持鍵名不變
對(duì)二維數(shù)組指定的鍵名排序,首先大家想到的是array_multisort函數(shù),關(guān)于array_multisort的用法我之前也寫了一篇廢話不多言,我們看個(gè)實(shí)例:
<?php $data = array( 1001 => array( 'age' => 22, 'name' => '鳩摩智' ), 1007 => array( 'age' => 21, 'name' => '慕容復(fù)' ), 1004 => array( 'age' => 27, 'name' => '喬幫主' ) ); //根據(jù)字段age對(duì)數(shù)組$data進(jìn)行升序排列 $ages = array_column($data, 'age'); array_multisort($ages, SORT_ASC, $data); print_r($data);
細(xì)心的朋友會(huì)看到,鍵名重置了,鍵名從0開(kāi)始,顯然這可能不是我們想要的結(jié)果,那如何保持鍵名不變?
我們?cè)倏磦€(gè)示例:
$data = array( 1001 => array( 'age' => 22, 'name' => '鳩摩智' ), 1007 => array( 'age' => 21, 'name' => '慕容復(fù)' ), 1004 => array( 'age' => 27, 'name' => '喬幫主' ) ); //根據(jù)字段age對(duì)數(shù)組$data進(jìn)行降序排列 $data = arraySort($data, "age", "desc" ); print_r($data); /** * @desc arraySort php二維數(shù)組排序 按照指定的key 對(duì)數(shù)組進(jìn)行自然排序 * @param array $arr 將要排序的數(shù)組 * @param string $keys 指定排序的key * @param string $type 排序類型 asc | desc * @return array */ function arraySort($arr, $keys, $type = 'asc') { $keysvalue = $new_array = array(); foreach ($arr as $k => $v) { $keysvalue[$k] = $v[$keys]; } if ($type == 'asc') { natsort($keysvalue); } if ($type == 'desc') { natsort($keysvalue); $keysvalue = array_reverse($keysvalue, TRUE); // 將原數(shù)組中的元素順序翻轉(zhuǎn),如果第二個(gè)參數(shù)指定為 true,則元素的鍵名保持不變 } foreach ($keysvalue as $k => $v) { $new_array[$k] = $arr[$k]; } return $new_array; }
這里我們也可以精簡(jiǎn)下arraySort函數(shù),處理結(jié)果相同:
/** * @desc arraySort php二維數(shù)組排序 按照指定的key 對(duì)數(shù)組進(jìn)行自然排序 * @param array $arr 將要排序的數(shù)組 * @param string $keys 指定排序的key * @param string $type 排序類型 asc | desc * @return array */ function arraySort($arr, $keys, $type = 'asc') { $keysvalue = $new_array = array(); foreach ($arr as $k => $v) { $keysvalue[$k] = $v[$keys]; } $type == 'asc' ? asort($keysvalue) : arsort($keysvalue); foreach ($keysvalue as $k => $v) { $new_array[$k] = $arr[$k]; } return $new_array; }
從上面的結(jié)果我們看到:
鍵名保持了不變,實(shí)現(xiàn)的原理很簡(jiǎn)單,先取出鍵名,然后對(duì)鍵名排序,再根據(jù)對(duì)應(yīng)的鍵名賦值組成新數(shù)組返回。
大家可以看到,這里我們主要用到了php的幾個(gè)核心的排序函數(shù)
asort() 對(duì)關(guān)聯(lián)數(shù)組按照鍵值進(jìn)行升序排序。
arsort()對(duì)關(guān)聯(lián)數(shù)組按照鍵值進(jìn)行降序排序。
natsort() 實(shí)現(xiàn)了“自然排序”,即數(shù)字從 1 到 9 的排序方法,字母從 a 到 z 的排序方法,短的優(yōu)先。數(shù)組的索引與單元值保持關(guān)聯(lián),
注意:在自然排序算法中,數(shù)字 2 小于 數(shù)字 10。在計(jì)算機(jī)排序算法中,10 小于 2,因?yàn)?"10" 中的第一個(gè)數(shù)字小于 2。
以上所述是小編給大家介紹的如何保持PHP 二維數(shù)組排序鍵名不變?cè)斀庹?,希望?duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
PHP中array_slice函數(shù)用法實(shí)例詳解
這篇文章主要介紹了PHP中array_slice函數(shù)用法,以實(shí)例形式詳細(xì)分析了array_slice函數(shù)的具體含義及使用技巧,并以分頁(yè)方法為例給出了具體的應(yīng)用實(shí)例,具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2014-11-11PHP 頁(yè)面跳轉(zhuǎn)到另一個(gè)頁(yè)面的多種方法方法總結(jié)
如何在PHP中從一個(gè)頁(yè)面重定向到另外一個(gè)頁(yè)面呢?這里列出了三種辦法,供參考。2009-07-07數(shù)據(jù)庫(kù)中排序的對(duì)比及使用條件詳解
PHP與MySQL數(shù)據(jù)庫(kù)中排序的對(duì)比及使用條件是本文我們主要要介紹的內(nèi)容,通常來(lái)說(shuō),執(zhí)行效率需要考慮CPU、內(nèi)存和硬盤等的負(fù)載情況2012-02-02php用戶注冊(cè)時(shí)常用的檢驗(yàn)函數(shù)實(shí)例總結(jié)
這篇文章主要介紹了php用戶注冊(cè)時(shí)常用的檢驗(yàn)函數(shù),以類的形式實(shí)例總結(jié)了用戶名驗(yàn)證、郵箱驗(yàn)證、QQ驗(yàn)證等常用的驗(yàn)證技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2014-12-12PHP中Socket連接及讀寫數(shù)據(jù)超時(shí)問(wèn)題分析
這篇文章主要介紹了PHP中Socket連接及讀寫數(shù)據(jù)超時(shí)問(wèn)題,分析了Socket連接的相關(guān)設(shè)置與使用技巧,需要的朋友可以參考下2016-07-07PHP json_encode中文亂碼問(wèn)題的解決辦法
這篇文章介紹了PHP json_encode中文亂碼問(wèn)題的解決辦法,有需要的朋友可以參考一下2013-09-09