• PHP array_multisort—对多个数组或多维数组进行排序


    PHP中array_multisort可以用来一次对多个数组进行排序,或者根据某一维或多维对多维数组进行排序。 

    关联(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' => 50
    10     ),
    11     
    12     '2' => array(
    13         'num1' => 4,
    14         'num2' => 44
    15     ),
    16     
    17     '3' => array(
    18         'num1' => 3,
    19         'num2' => 78
    20     ) 
    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
      )

    )
  • 相关阅读:
    HDFS升级域:Upgrade Domain
    HDFS升级域:Upgrade Domain
    HDFS数据快速拷贝方案:FastCopy
    HDFS数据快速拷贝方案:FastCopy
    Confluence 6 SQL Server 测试你的数据库连接
    Confluence 6 SQL Server 输入你的数据库细节
    Confluence 6 SQL Server 创建一个数据库和数据库用户
    Confluence 6 安装 SQL Server
    Confluence 6 Microsoft SQL Server 设置准备
    Confluence 6 Oracle 连接问题解决
  • 原文地址:https://www.cnblogs.com/liangzia/p/6155760.html
Copyright © 2020-2023  润新知