PHP array_multisort—對多個數組或多維陣列進行排序

來源:互聯網
上載者:User

標籤:eric   tle   order   理解   log   預設值   each   數組   [1]   

關聯(string)鍵名保持不變,但數字鍵名會被重新索引。 
輸入數組被當成一個表的列並以行來排序——這類似於 SQL 的 ORDER BY 子句的功能。第一個數組是要排序的主要數組。數組中的行(值)比較為相同的話就按照下一個輸入數組中相應值的大小來排序,依此類推。——這句話是理解此函數用法的關鍵。

第一個參數必須是一個數組。接下來的每個參數可以是數組或者是下面列出的排序標誌。

排序次序標誌: 
■SORT_ASC - 按照上升順序排序 
■SORT_DESC - 按照下降順序排序

排序類型標誌: 
■SORT_REGULAR - 將項目按照通常方法比較 
■SORT_NUMERIC - 將項目按照數值比較 
■SORT_STRING - 將項目按照字串比較

每個數組之後不能指定兩個同類的排序標誌。每個數組後指定的排序標誌僅對該數組有效 - 在此之前為預設值 SORT_ASC 和 SORT_REGULAR。

看看兩個實際例子:

1、一次對多個數組進行排序:

 
1 $num1 = array(3, 5, 4, 3);2 $num2 = array(27, 50, 44, 78);3 array_multisort($num1, SORT_ASC, $num2, SORT_DESC);4 5 print_r($num1);6 print_r($num2);7 //result: Array ( [0] => 3 [1] => 3 [2] => 4 [3] => 5 ) Array ( [0] => 78 [1] => 27 [2] => 44 [3] => 50 ) 
 

2、對多維陣列(以二位元組為例)進行排序:

 
1 $arr = array( 2     ‘0‘ => array( 3         ‘num1‘ => 3, 4         ‘num2‘ => 27  5     ), 6      7     ‘1‘ => array( 8         ‘num1‘ => 5, 9         ‘num2‘ => 5010     ),11     12     ‘2‘ => array(13         ‘num1‘ => 4,14         ‘num2‘ => 4415     ),16     17     ‘3‘ => array(18         ‘num1‘ => 3,19         ‘num2‘ => 7820     ) 21 );22 23 foreach ( $arr as $key => $row ){24     $num1[$key] = $row [‘num1‘];25     $num2[$key] = $row [‘num2‘];26 }27 28 array_multisort($num1, SORT_ASC, $num2, SORT_DESC, $arr);29 
echo "<pre>";30 print_r($arr);31 echo "</pre>";

運行結果:

Array
(
  [0] => Array
  (
    [id] => 2
    [price] => 70
  )

  [1] => Array
  (
    [id] => 1
    [price] => 50
  )

  [2] => Array
  (
    [id] => 3
    [price] => 30
  )

  [3] => Array
  (
    [id] => 4
    [price] => 20
  )

)

PHP array_multisort—對多個數組或多維陣列進行排序

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.