PHP將二位陣列按照第二維的某個元素的值進行排序
//原始陣列是這樣的,希望能夠按照第二維中的run_date升序或者降序進行排序:
$arr=array( 0=>array( 'run_date'=>'2017-11-21', 'count'=>'5' ), 1=>array( 'run_date'=>'2017-11-20', 'count'=>'10' ), 2=>array( 'run_date'=>'2017-11-22', 'count'=>'10' ) ); //希望得到: $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' ) );
當然,用迴圈遍歷是可以解決的,但是還是覺得效率有點低,這裡有另外一個解決方案,是使用兩個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即可