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

首頁 > 語言 > PHP > 正文

詳解PHP 二維數(shù)組排序保持鍵名不變

2024-05-05 00:07:11
字體:
供稿:網(wǎng)友

 對二維數(shù)組指定的鍵名排序,首先大家想到的是array_multisort函數(shù),關(guān)于array_multisort的用法我之前也寫了一篇廢話不多言,我們看個實例:

<?php$data = array( 1001 => array( 'age' => 22, 'name' => '鳩摩智' ), 1007 => array( 'age' => 21, 'name' => '慕容復(fù)' ), 1004 => array( 'age' => 27, 'name' => '喬幫主' ));//根據(jù)字段age對數(shù)組$data進行升序排列 $ages = array_column($data, 'age'); array_multisort($ages, SORT_ASC, $data); print_r($data);

PHP,二維數(shù)組,排序,鍵名

細心的朋友會看到,鍵名重置了,鍵名從0開始,顯然這可能不是我們想要的結(jié)果,那如何保持鍵名不變?
我們再看個示例:

$data = array( 1001 => array( 'age' => 22, 'name' => '鳩摩智' ), 1007 => array( 'age' => 21, 'name' => '慕容復(fù)' ), 1004 => array( 'age' => 27, 'name' => '喬幫主' ));//根據(jù)字段age對數(shù)組$data進行降序排列$data = arraySort($data, "age", "desc" );print_r($data);/** * @desc arraySort php二維數(shù)組排序 按照指定的key 對數(shù)組進行自然排序 * @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),如果第二個參數(shù)指定為 true,則元素的鍵名保持不變 } foreach ($keysvalue as $k => $v) { $new_array[$k] = $arr[$k]; } return $new_array;}

這里我們也可以精簡下arraySort函數(shù),處理結(jié)果相同:

/** * @desc arraySort php二維數(shù)組排序 按照指定的key 對數(shù)組進行自然排序 * @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é)果我們看到:

PHP,二維數(shù)組,排序,鍵名

鍵名保持了不變,實現(xiàn)的原理很簡單,先取出鍵名,然后對鍵名排序,再根據(jù)對應(yīng)的鍵名賦值組成新數(shù)組返回。
大家可以看到,這里我們主要用到了php的幾個核心的排序函數(shù)

asort() 對關(guān)聯(lián)數(shù)組按照鍵值進行升序排序。

arsort()對關(guān)聯(lián)數(shù)組按照鍵值進行降序排序。

natsort() 實現(xiàn)了“自然排序”,即數(shù)字從 1 到 9 的排序方法,字母從 a 到 z 的排序方法,短的優(yōu)先。數(shù)組的索引與單元值保持關(guān)聯(lián),

注意:在自然排序算法中,數(shù)字 2 小于 數(shù)字 10。在計算機排序算法中,10 小于 2,因為 "10" 中的第一個數(shù)字小于 2。

以上所述是小編給大家介紹的如何保持PHP 二維數(shù)組排序鍵名不變詳解整合,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對VeVb武林網(wǎng)網(wǎng)站的支持!


注:相關(guān)教程知識閱讀請移步到PHP教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 广饶县| 三穗县| 石阡县| 仪陇县| 道真| 中宁县| 沧州市| 鹿泉市| 岳普湖县| 田东县| 雷波县| 镇康县| 澄城县| 兴业县| 太保市| 京山县| 安龙县| 榆社县| 嘉黎县| 嘉兴市| 宣武区| 罗田县| 华池县| 宁阳县| 若羌县| 安阳市| 亚东县| 门头沟区| 牡丹江市| 湘潭县| 宿州市| 紫云| 娄底市| 利川市| 蒙阴县| 扎囊县| 历史| 石河子市| 东乡县| 沽源县| 绩溪县|