PHP將二位數組按照第二維的某個元素的值進行排序


例如:

 1 //原始數組是這樣的,希望能夠按照第二維中的run_date升序或者降序進行排序:
 2 $arr=array(
 3                 0=>array(
 4                     'run_date'=>'2017-11-21',
 5                     'count'=>'5'
 6                 ),
 7                 1=>array(
 8                     'run_date'=>'2017-11-20',
 9                     'count'=>'10'
10                 ),
11                 2=>array(
12                     'run_date'=>'2017-11-22',
13                     'count'=>'10'
14                 )
15             );
16 //希望得到:
17 $arr=array(
18                 0=>array(
19                     'run_date'=>'2017-11-20',
20                     'count'=>'5'
21                 ),
22                 1=>array(
23                     'run_date'=>'2017-11-21',
24                     'count'=>'10'
25                 ),
26                 2=>array(
27                     'run_date'=>'2017-11-22',
28                     'count'=>'10'
29                 )
30 );

當然,用循環遍歷是可以解決的,但是還是覺得效率有點低,這里有另外一個解決方案,是使用兩個PHP提供的函數:

array_column array_multisort

還是上面的數組:
//先用array_column 多維數組按照縱向(列)取出

$date = array_column($arr, 'run_date');

//上面得到的結果:array(0=>'2017-11-21',1=>'2017-11-20',3=>'2017-11-22')

//再用array_multisort  結合array_column得到的結果對$arr進行排序

array_multisort($date,SORT_ASC,$arr);

//最終的結果:
$arr=array(
                0=>array(
                    'run_date'=>'2017-11-20',
                    'count'=>'5'
                ),
                1=>array(
                    'run_date'=>'2017-11-21',
                    'count'=>'10'
                ),
                2=>array(
                    'run_date'=>'2017-11-22',
                    'count'=>'10'
                )
            );

附:

1、array_column 參考我之前的博客 http://www.cnblogs.com/Steven-shi/p/5897745.html

2、array_multisort array_multisort() 函數對多個數組或多維數組進行排序,可以用來一次對多個PHP二維數組排序進行排序,或者根據某一維或多維對多維數組進行排序

參數中的數組被當成一個表的列並以行來進行排序 - 這類似 SQL 的 ORDER BY 子句的功能。第一個數組是要排序的主要數組。數組中的行(值)比較為相同的話,就會按照下一個輸入數組中相應值的大小進行排序,依此類推。

第一個參數是數組,隨后的每一個參數可能是數組,也可能是下面的排序順序標志(排序標志用於更改默認的排列順序)之一:

SORT_ASC - 默認,按升序排列。(A-Z)
SORT_DESC - 按降序排列。(Z-A)
隨后可以指定排序的類型:

SORT_REGULAR - 默認。將每一項按常規順序排列。
SORT_NUMERIC - 將每一項按數字順序排列。
SORT_STRING - 將每一項按字母順序排列。
array_multisort(array1,sorting order,sorting type,array2,array3...)
array1 : 必需。規定輸入的數組。

sorting order : 可選。規定排列順序。可能的值是 SORT_ASC 和 SORT_DESC。

sorting type : 可選。規定排序類型。可能的值是SORT_REGULAR、SORT_NUMERIC和SORT_STRING。

array2 : 可選。規定輸入的數組。

array3 : 可選。規定輸入的數組。

注釋:字符串鍵名將被保留,但是數字鍵將被重新索引,從 0 開始,並以 1 遞增。

注釋:您可以在每個數組后設置排序順序和排序類型。如果沒有設置,每個數組參數會使用默認值。

PHP二維數組排序是按照第一個數組進行排序,並且調整后面的順序。像這樣的數組:

array( 'id' => array(1,3,2), 'data'=>array('a','c','b'))

只要按照id進行多維排序,就可以了。但是很多時候,我們構造出的數組是這樣的:

array( array('id'=>1,'data'=>'a'), array('id'=>3,'data'=>'c'), array('id'=>2,'data'=>'b') );

PHP二維數組排序的元素是按行排列的,需要按其中的一列進行排序。PHP好像也沒提供類似矩陣轉置的函數,所以不能直接使用array_multisort進行多維排序。不過只需要先把排序的列抽取出來,作為第一個參數傳給array_multisort即可


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM