php對數(shù)組排序并保持鍵值不變的方法:首先我們需要取出數(shù)組的鍵名;然后對鍵名進(jìn)行排序;最后根據(jù)對應(yīng)的鍵名進(jìn)行賦值,組成一個(gè)新數(shù)組并返回即可。
十年的三門網(wǎng)站建設(shè)經(jīng)驗(yàn),針對設(shè)計(jì)、前端、開發(fā)、售后、文案、推廣等六對一服務(wù),響應(yīng)快,48小時(shí)及時(shí)工作處理。成都全網(wǎng)營銷推廣的優(yōu)勢是能夠根據(jù)用戶設(shè)備顯示端的尺寸不同,自動(dòng)調(diào)整三門建站的顯示方式,使網(wǎng)站能夠適用不同顯示終端,在瀏覽器中調(diào)整網(wǎng)站的寬度,無論在任何一種瀏覽器上瀏覽網(wǎng)站,都能展現(xiàn)優(yōu)雅布局與設(shè)計(jì),從而大程度地提升瀏覽體驗(yàn)。創(chuàng)新互聯(lián)從事“三門網(wǎng)站設(shè)計(jì)”,“三門網(wǎng)站推廣”以來,每個(gè)客戶項(xiàng)目都認(rèn)真落實(shí)執(zhí)行。
實(shí)現(xiàn)代碼:
(推薦教程:php視頻教程)
$data = array( 1001 => array( 'age' => 22, 'name' => '鳩摩智' ), 1007 => array( 'age' => 21, 'name' => '慕容復(fù)' ), 1004 => array( 'age' => 27, 'name' => '喬幫主' ) ); //根據(jù)字段age對數(shù)組$data進(jìn)行降序排列 $data = arraySort($data, "age", "desc" ); print_r($data); /** * @desc arraySort php二維數(shù)組排序 按照指定的key 對數(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; }
這里我們也可以精簡下arraySort函數(shù),處理結(jié)果相同:
/** * @desc arraySort php二維數(shù)組排序 按照指定的key 對數(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)的原理很簡單,先取出鍵名,然后對鍵名排序,再根據(jù)對應(yīng)的鍵名賦值組成新數(shù)組返回。
大家可以看到,這里我們主要用到了php的幾個(gè)核心的排序函數(shù)。
asort() 對關(guān)聯(lián)數(shù)組按照鍵值進(jìn)行升序排序。
arsort()對關(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。
相關(guān)推薦:php培訓(xùn)
當(dāng)前標(biāo)題:php如何對數(shù)組排序并保持鍵值不變
文章起源:http://www.rwnh.cn/article30/cpigpo.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供微信小程序、微信公眾號、動(dòng)態(tài)網(wǎng)站、用戶體驗(yàn)、品牌網(wǎng)站設(shè)計(jì)、營銷型網(wǎng)站建設(shè)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)