欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

PHP中如何實現(xiàn)二維數(shù)組排序保持鍵名不變

小編給大家分享一下PHP中如何實現(xiàn)二維數(shù)組排序保持鍵名不變,希望大家閱讀完這篇文章后大所收獲,下面讓我們一起去探討吧!

成都創(chuàng)新互聯(lián)公司主營連江網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司,主營網(wǎng)站建設(shè)方案,手機APP定制開發(fā),連江h(huán)5微信平臺小程序開發(fā)搭建,連江網(wǎng)站營銷推廣歡迎連江等地區(qū)企業(yè)咨詢

對二維數(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' => '喬幫主'
    )
);
 

 = array_column(, 'age'(, SORT_ASC, ();

PHP中如何實現(xiàn)二維數(shù)組排序保持鍵名不變

細(xì)心的朋友會看到,鍵名重置了,鍵名從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é)果我們看到:
PHP中如何實現(xiàn)二維數(shù)組排序保持鍵名不變

鍵名保持了不變,實現(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中如何實現(xiàn)二維數(shù)組排序保持鍵名不變有了一定的了解,想了解更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!

分享題目:PHP中如何實現(xiàn)二維數(shù)組排序保持鍵名不變
文章轉(zhuǎn)載:http://www.aaarwkj.com/article38/pjdipp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供微信公眾號、動態(tài)網(wǎng)站、網(wǎng)站內(nèi)鏈、網(wǎng)站設(shè)計、網(wǎng)站維護、全網(wǎng)營銷推廣

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

微信小程序開發(fā)
日韩免费系列一区二区| 高清欧美一区二区三区日本| 欧美亚洲午夜一二综合| 国产综合一区在线观看97| 给我搜一个一级黄色片| 久久av天堂在线观看| 一区二区三区在线观看美女视频 | 欧美黄色日本一区二区| 91亚洲蜜臀精品国产| 亚洲视频在线视频看视频在线| 蜜臀视频一区二区在线播放| 久久精品国产亚洲av高清大结局| 一区二区三区毛片视频| 日本午夜熟女九色视频| 国产精品国产三级国产普通话99 | 欧美乱与老熟妇视频观看| 精品一二三区在线天堂| 亚洲国产精品有码专区| 日韩亚洲av在线免费观看| 亚洲一区二区精品999| 91熟女成人精品一区二区| 男人午夜福利视频在线观看| 黄色录像一级大片中国的| 精品国产一区二区三区精品日韩| 国产午夜18久久久| 免费看真人性生活视频| 农村人妻一区二区三区视频| 久久精品亚洲熟女av蜜謦| 日本美女阴部毛茸茸视频| 国产麻豆精品免费喷白浆视频网站| 黄片大全在线免费视频观看| 天天躁日日躁夜夜躁夜夜| 99亚洲伊人久久精品影院| 久久国产精品亚洲av四虎| 亚洲黄色一区大陆av剧情| 亚洲精品国产熟女久久| 亚洲欧美日韩午夜在线| 亚洲国产综合六月深深爱| 人妻少妇中文字幕在线播放| 成人免费av在线网址| 女人裸体网站无遮挡午夜|