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


    2维数组或者多维数组排序是常见的问题,在PHP中我们有个专门的多维数组排序函数,下面简单介绍下:

    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 可选。规定输入的数组。

    参数中的数组被当成一个表的列并以行来进行排序 - 这类似 SQL 的 ORDER BY 子句的功能。第一个数组是要排序的主要数组。数组中的行(值)比较为相同的话,就会按照下一个输入数组中相应值的大小进行排序,依此类推。

    第一个参数是数组,随后的每一个参数可能是数组,也可能是下面的排序顺序标志(排序标志用于更改默认的排列顺序)之一:

    • SORT_ASC - 默认,按升序排列。(A-Z)
    • SORT_DESC - 按降序排列。(Z-A)

    随后可以指定排序的类型:

      • SORT_REGULAR - 默认。将每一项按常规顺序排列。
      • SORT_NUMERIC - 将每一项按数字顺序排列。
      • SORT_STRING - 将每一项按字母顺序排列

    重点就是,先把要排序的key存到一个一维数组中,然后就可以使用array_multisort()这个函数,将数组按照key进行排序了

    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 
    30 print_r($arr);
    31 //result:Array([0]=>Array([num1]=>3 [num2]=>78) [1]=>Array([num1]=>3 [num2]=>27) [2]=>Array([num1]=>4 [num2]=>44) [3]=>Array([num1]=>5 [num2]=>50))
  • 相关阅读:
    RHEL虚机分区在线扩容操作指导说明
    Kafka vs AMQ技术比对
    数据库选型之MySQL vs ElasticSearch
    JAVA ElasticSearch 访问控制最佳解决方案
    EFS解密----未重装系统
    EFS加密解密----重装系统后
    EXCEL表格单元格中包含数字英文和汉字,如何自动去掉汉字,保留英文和数字
    excel如何用公式判断单元格的值是否为数字、英文、中文,以及相应的计数
    EXCEL计算数字、汉字、英文单元格的计数
    sql基本操作
  • 原文地址:https://www.cnblogs.com/xs-yqz/p/6439359.html
Copyright © 2020-2023  润新知