對二維數(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);

細心的朋友會看到,鍵名重置了,鍵名從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é)果我們看到:

鍵名保持了不變,實現(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ù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
您可能感興趣的文章:- php對二維數(shù)組按指定鍵值key排序示例代碼
- php數(shù)組實現(xiàn)根據(jù)某個鍵值將相同鍵值合并生成新二維數(shù)組的方法
- PHP二維數(shù)組實現(xiàn)去除重復(fù)項的方法【保留各個鍵值】
- PHP按指定鍵值對二維數(shù)組進行排序的方法
- php二維數(shù)組按某個鍵值排序的實例講解
- php自定義排序uasort函數(shù)示例【二維數(shù)組按指定鍵值排序】
- php二維數(shù)組用鍵名分組相加實例函數(shù)
- PHP實現(xiàn)二維數(shù)組按指定的鍵名排序的方法示例
- PHP實現(xiàn)通過二維數(shù)組鍵值獲取一維鍵名操作示例