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

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

php對(duì)數(shù)組排序并保持鍵值不變的方法

php對(duì)數(shù)組排序并保持鍵值不變的方法?這個(gè)問(wèn)題可能是我們?nèi)粘W(xué)習(xí)或工作經(jīng)常見到的。希望通過(guò)這個(gè)問(wèn)題能讓你收獲頗深。下面是小編給大家?guī)?lái)的參考內(nèi)容,讓我們一起來(lái)看看吧!

員工經(jīng)過(guò)長(zhǎng)期磨合與沉淀,具備了協(xié)作精神,得以通過(guò)團(tuán)隊(duì)的力量開發(fā)出優(yōu)質(zhì)的產(chǎn)品。創(chuàng)新互聯(lián)建站堅(jiān)持“專注、創(chuàng)新、易用”的產(chǎn)品理念,因?yàn)椤皩W⑺詫I(yè)、創(chuàng)新互聯(lián)網(wǎng)站所以易用所以簡(jiǎn)單”。公司專注于為企業(yè)提供做網(wǎng)站、成都網(wǎng)站設(shè)計(jì)、微信公眾號(hào)開發(fā)、電商網(wǎng)站開發(fā),重慶小程序開發(fā),軟件定制網(wǎng)站設(shè)計(jì)等一站式互聯(lián)網(wǎng)企業(yè)服務(wù)。

php對(duì)數(shù)組排序并保持鍵值不變的方法:首先我們需要取出數(shù)組的鍵名;然后對(duì)鍵名進(jìn)行排序;最后根據(jù)對(duì)應(yīng)的鍵名進(jìn)行賦值,組成一個(gè)新數(shù)組并返回即可。

實(shí)現(xiàn)代碼:

$data = array(
    1001 => array(
        'age' => 22,
        'name' => '鳩摩智'
    ),
    1007 => array(
        'age' => 21,
        'name' => '慕容復(fù)'
    ),
    1004 => array(
        'age' => 27,
        'name' => '喬幫主'
    )
);
//根據(jù)字段age對(duì)數(shù)組$data進(jìn)行降序排列
$data = arraySort($data, "age", "desc" );
print_r($data);

/**
 * @desc arraySort php二維數(shù)組排序 按照指定的key 對(duì)數(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;
}

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

/**
 * @desc arraySort php二維數(shù)組排序 按照指定的key 對(duì)數(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é)果:

php對(duì)數(shù)組排序并保持鍵值不變的方法

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

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

arsort()對(duì)關(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。

感謝各位的閱讀!看完上述內(nèi)容,你們對(duì)php對(duì)數(shù)組排序并保持鍵值不變的方法大概了解了嗎?希望文章內(nèi)容對(duì)大家有所幫助。如果想了解更多相關(guān)文章內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。


本文標(biāo)題:php對(duì)數(shù)組排序并保持鍵值不變的方法
地址分享:http://weahome.cn/article/jgisoo.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部