對二維數組指定的鍵名排序,首先大家想到的是array_multisort函數,關於array_multisort的用法我之前也寫了一篇廢話不多言,我們看個實例: 細心的朋友會看到,鍵名重置了,鍵名從0開始,顯然這可能不是我們想要的結果,那如何保持鍵名不變? 我們再看個示例: 這裡我們也可以精簡下ar ...
對二維數組指定的鍵名排序,首先大家想到的是array_multisort函數,關於array_multisort的用法我之前也寫了一篇
廢話不多言,我們看個實例:
<?php
$data = array(
1001 => array(
'age' => 22,
'name' => '鳩摩智'
),
1007 => array(
'age' => 21,
'name' => '慕容復'
),
1004 => array(
'age' => 27,
'name' => '喬幫主'
)
);
//根據欄位age對數組$data進行升序排列
$ages = array_column($data, 'age');
array_multisort($ages, SORT_ASC, $data);
print_r($data);
細心的朋友會看到,鍵名重置了,鍵名從0開始,顯然這可能不是我們想要的結果,那如何保持鍵名不變?
我們再看個示例:
$data = array( 1001 => array( 'age' => 22, 'name' => '鳩摩智' ), 1007 => array( 'age' => 21, 'name' => '慕容復' ), 1004 => array( 'age' => 27, 'name' => '喬幫主' ) ); //根據欄位age對數組$data進行降序排列 $data = arraySort($data, "age", "desc" ); print_r($data); /** * @desc arraySort php二維數組排序 按照指定的key 對數組進行自然排序 * @param array $arr 將要排序的數組 * @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); // 將原數組中的元素順序翻轉,如果第二個參數指定為 true,則元素的鍵名保持不變 } foreach ($keysvalue as $k => $v) { $new_array[$k] = $arr[$k]; } return $new_array; }
這裡我們也可以精簡下arraySort函數,處理結果相同:
/** * @desc arraySort php二維數組排序 按照指定的key 對數組進行自然排序 * @param array $arr 將要排序的數組 * @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; }
從上面的結果我們看到:
鍵名保持了不變,實現的原理很簡單,先取出鍵名,然後對鍵名排序,再根據對應的鍵名賦值組成新數組返回。
大家可以看到,這裡我們主要用到了php的幾個核心的排序函數
asort() 對關聯數組按照鍵值進行升序排序。 arsort()對關聯數組按照鍵值進行降序排序。 natsort() 實現了“自然排序”,即數字從 1 到 9 的排序方法,字母從 a 到 z 的排序方法,短的優先。數組的索引與單元值保持關聯, 註意:在自然排序演算法中,數字 2 小於 數字 10。在電腦排序演算法中,10 小於 2,因為 "10" 中的第一個數字小於 2。