真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

PHP二維數(shù)組排序保持鍵名不變的方法

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

創(chuàng)新互聯(lián)建站專注于永春網(wǎng)站建設(shè)服務(wù)及定制,我們擁有豐富的企業(yè)做網(wǎng)站經(jīng)驗。 熱誠為您提供永春營銷型網(wǎng)站建設(shè),永春網(wǎng)站制作、永春網(wǎng)頁設(shè)計、永春網(wǎng)站官網(wǎng)定制、成都小程序開發(fā)服務(wù),打造永春網(wǎng)絡(luò)公司原創(chuàng)品牌,更為您提供永春網(wǎng)站排名全網(wǎng)營銷落地服務(wù)。
$data = array(
    1001 => array(
        'age' => 22,
        'name' => '鳩摩智'
    ),
    1007 => array(
        'age' => 21,
        'name' => '慕容復(fù)'
    ),
    1004 => array(
        'age' => 27,
        'name' => '喬幫主'
    )
);
 = array_column(, 'age'(, SORT_ASC, ();

細心的朋友會看到,鍵名重置了,鍵名從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。

相關(guān)學(xué)習推薦:php編程(視頻)


當前標題:PHP二維數(shù)組排序保持鍵名不變的方法
文章URL:http://weahome.cn/article/cjhcii.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部