日日操夜夜添-日日操影院-日日草夜夜操-日日干干-精品一区二区三区波多野结衣-精品一区二区三区高清免费不卡

公告:魔扣目錄網(wǎng)為廣大站長提供免費收錄網(wǎng)站服務,提交前請做好本站友鏈:【 網(wǎng)站目錄:http://www.ylptlb.cn 】, 免友鏈快審服務(50元/站),

點擊這里在線咨詢客服
新站提交
  • 網(wǎng)站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會員:747

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


PHP如何對數(shù)組排序并保持鍵值不變


實現(xiàn)代碼:

$data = array(
    1001 => array(
        'age' => 22,
        'name' => '鳩摩智'
    ),
    1007 => array(
        'age' => 21,
        'name' => '慕容復'
    ),
    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ù)組中的元素順序翻轉,如果第二個參數(shù)指定為 true,則元素的鍵名保持不變
    }
    foreach ($keysvalue as $k => $v) {
        $new_array[$k] = $arr[$k];
    }
    return $new_array;
}

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

/**
 * @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;
}

輸出結果:


PHP如何對數(shù)組排序并保持鍵值不變


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

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

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

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

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



分享到:
標簽:PHP 數(shù)組排序 鍵值不變
用戶無頭像

網(wǎng)友整理

注冊時間:

網(wǎng)站:5 個   小程序:0 個  文章:12 篇

  • 51998

    網(wǎng)站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會員

趕快注冊賬號,推廣您的網(wǎng)站吧!
最新入駐小程序

數(shù)獨大挑戰(zhàn)2018-06-03

數(shù)獨一種數(shù)學游戲,玩家需要根據(jù)9

答題星2018-06-03

您可以通過答題星輕松地創(chuàng)建試卷

全階人生考試2018-06-03

各種考試題,題庫,初中,高中,大學四六

運動步數(shù)有氧達人2018-06-03

記錄運動步數(shù),積累氧氣值。還可偷

每日養(yǎng)生app2018-06-03

每日養(yǎng)生,天天健康

體育訓練成績評定2018-06-03

通用課目體育訓練成績評定