溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何在PHP中對二維數(shù)組進行排序

發(fā)布時間:2021-01-05 16:24:23 來源:億速云 閱讀:170 作者:Leah 欄目:開發(fā)技術(shù)

這篇文章給大家介紹如何在PHP中對二維數(shù)組進行排序,內(nèi)容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。

一、用PHP自帶array_multisort函數(shù)排序 

復制代碼 代碼如下:


<?php

    $data = array();
    $data[] = array('volume' => 67, 'edition' => 2);
    $data[] = array('volume' => 86, 'edition' => 1);
    $data[] = array('volume' => 85, 'edition' => 6);
    $data[] = array('volume' => 98, 'edition' => 2);
    $data[] = array('volume' => 86, 'edition' => 6);
    $data[] = array('volume' => 67, 'edition' => 7);

    // 取得列的列表
    foreach ($data as $key => $row)
    {
        $volume[$key]  = $row['volume'];
        $edition[$key] = $row['edition'];
    }

    array_multisort($volume, SORT_DESC, $edition, SORT_ASC, $data);

    print_r($data);
?>

輸出結(jié)果:

復制代碼 代碼如下:

Array
(
    [0] => Array
        (
            [volume] => 98
            [edition] => 2
        )
    [1] => Array
        (
            [volume] => 86
            [edition] => 1
        )
    [2] => Array
        (
            [volume] => 86
            [edition] => 6
        )
    [3] => Array
        (
            [volume] => 85
            [edition] => 6
        )
    [4] => Array
        (
            [volume] => 67
            [edition] => 2
        )
    [5] => Array
        (
            [volume] => 67
            [edition] => 7
        )
)

關(guān)于array_multisort官方文檔也有比較詳細的說明:http://www.php.net/manual/zh/function.array-multisort.php

二、自定義函數(shù)排序1

復制代碼 代碼如下:


<?php
    $data = array();
    $data[] = array('volume' => 67, 'edition' => 2);
    $data[] = array('volume' => 86, 'edition' => 1);
    $data[] = array('volume' => 85, 'edition' => 6);
    $data[] = array('volume' => 98, 'edition' => 2);
    $data[] = array('volume' => 86, 'edition' => 6);
    $data[] = array('volume' => 67, 'edition' => 7);

    // 取得列的列表
    foreach ($data as $key => $row)
    {
        $volume[$key]  = $row['volume'];
        $edition[$key] = $row['edition'];
    }

    $ret = arraySort($data, 'volume', 'desc');

    print_r($ret);

    /**
     * @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);
        reset($keysvalue);
        foreach ($keysvalue as $k => $v) {
           $new_array[$k] = $arr[$k];
        }
        return $new_array;
    }
?>
輸出結(jié)果:

復制代碼 代碼如下:

Array
(
    [3] => Array
        (
            [volume] => 98
            [edition] => 2
        )

    [4] => Array
        (
            [volume] => 86
            [edition] => 6
        )

    [1] => Array
        (
            [volume] => 86
            [edition] => 1
        )

    [2] => Array
        (
            [volume] => 85
            [edition] => 6
        )

    [5] => Array
        (
            [volume] => 67
            [edition] => 7
        )

    [0] => Array
        (
            [volume] => 67
            [edition] => 2
        )

)

這個自定義函數(shù)與系統(tǒng)函數(shù)的一個區(qū)別就是:自定義函數(shù)只支持針對某一個key的排序,如果要支持多個key的排序需要執(zhí)行多次; 而系統(tǒng)函數(shù)array_multisort可以一次性對多個key且可以指定多個排序規(guī)則,系統(tǒng)函數(shù)還是相當強大的,推薦使用系統(tǒng)函數(shù),畢竟是C底層實現(xiàn)的,這里只是舉例說明如果通過自定義函數(shù)來對數(shù)組進行排序,當然這個自定義函數(shù)也可以繼續(xù)擴展來支持更多的排序規(guī)則。在取排名、排行榜、成績等場景中用到的還是非常多的。

三、自定義函數(shù)排序2

以下函數(shù)是對一個給定的二維數(shù)組按照指定的鍵值進行排序,先看函數(shù)定義:

復制代碼 代碼如下:


function array_sort($arr,$keys,$type='asc'){
 $keysvalue = $new_array = array();
 foreach ($arr as $k=>$v){
  $keysvalue[$k] = $v[$keys];
 }
 if($type == 'asc'){
  asort($keysvalue);
 }else{
  arsort($keysvalue);
 }
 reset($keysvalue);
 foreach ($keysvalue as $k=>$v){
  $new_array[$k] = $arr[$k];
 }
 return $new_array;
}


它可以對二維數(shù)組按照指定的鍵值進行排序,也可以指定升序或降序排序法(默認為升序),用法示例:

復制代碼 代碼如下:


$array = array(
 array('name'=>'手機','brand'=>'諾基亞','price'=>1050),
 array('name'=>'筆記本電腦','brand'=>'lenovo','price'=>4300),
 array('name'=>'剃須刀','brand'=>'飛利浦','price'=>3100),
 array('name'=>'跑步機','brand'=>'三和松石','price'=>4900),
 array('name'=>'手表','brand'=>'卡西歐','price'=>960),
 array('name'=>'液晶電視','brand'=>'索尼','price'=>6299),
 array('name'=>'激光打印機','brand'=>'惠普','price'=>1200)
);

$ShoppingList = array_sort($array,'price');
print_r($ShoppingList);

上面是對$array這個二維數(shù)組按照'price'從低到高的排序。

關(guān)于如何在PHP中對二維數(shù)組進行排序就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI