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


    From: http://www.cnblogs.com/lwbqqyumidi/archive/2013/01/31/2887188.html

    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))
    复制代码
    --------------------------------------------------------------------------------- 
    笔者水平有限,若有错漏,欢迎指正,欢迎转载以及CV操作,但希注明出处,谢谢!
  • 相关阅读:
    angular 按下回车键触发事件
    vue 父组件与子组件的通信
    最近在开发一个文章聚合的工具
    Martinjingyu的开发环境
    个推push数据统计(爬虫)
    基于redis的订单号生成方案
    电商平台--Mysql主从搭建(2)
    Mysql主从搭建(1)
    mysql物理级别热备脚本
    外键查询及删除
  • 原文地址:https://www.cnblogs.com/joeblackzqq/p/5143862.html
Copyright © 2020-2023  润新知