array_multisort函数,以及多维数组下排序的应用,并与usort函数对比
以前比较少用这个函数,大部分自己接触的业务里,处理稍微大一些的数组的时候几乎都是从db里取出来的,在db里就order by了。
最近倒是用了次,这个函数用来排序很强大,有点类似于sql中的order by,更像order by 后边有多个列名的时候(就是先以第一个列排序,然后再排第二列顺序这样)。这个函数尤其在多维数组排序的时候很有用。
php参考手册:http://php.net/manual/zh/function.array-multisort.php
手册里头这句话,对于理解这个函数的用法很重要:输入数组被当成一个表的列并以行来排序——这类似于 SQL 的 ORDER BY 子句的功能。第一个数组是要排序的主要数组。数组中的行(值)比较为相同的话就按照下一个输入数组中相应值的大小来排序,依此类推。
简单举个例子:
$arr1 = array(5,4,3,1,1);
$arr2 = array(1,2,3,4,5);
array_multisort($arr1, $arr2);
结果发现$arr1的顺序是1,1,3,4,5,$arr2的顺序是4,5,3,2,1。
排序时类似这样:把这两个数组倒过来,arr1、arr2是一张表的表头,如下所示。
arr1 arr2
5 1
4 2
3 3
1 4
1 5
它类似于sql中的 order by arr1, arr2 。。
按照arr1排序时,发现有两个1,那么则按照arr2排序,因为默认是按照升序排,所以arr2中的4这一行排在第一行位置,arr2中的5这一行排在第二行。
结果就是这样:
arr1 arr2
1 4
1 5
3 3
4 2
5 1
相信能明白了吧哈哈~
这个排序,会比较有用的地方在于多维数组的排序,来举个例子。
比如given一个数组是这样的,结果要按照title升序排,如果title一样,按照age降序排。
<?php // 按照title升序,age降序 排列
$arr = array(
array(
'id' => 1,
'nickname' => 'James',
'title' => 'a',
'age' => 30,
),
array(
'id' => 2,
'nickname' => 'Wade',
'title' => 'b',
'age' => 31,
),
array(
'id' => 3,
'nickname' => 'Bosh',
'title' => 'c',
'age' => 32,
),
array(
'id' => 4,
'nickname' => 'Durant',
'title' => 'a',
'age' => 27,
),
array(
'id' => 5,
'nickname' => 'Howard',
'title' => 'b',
'age' => 32,
),
);
使用array_multisort()函数:
print_r($arr); // 把参加排序的字段, 拆出来成各个数组
foreach($arr as $v){
$arr_title[] = $v['title'];
$arr_age[] = $v['age'];
} // 排序,注意最后一个参数是希望得到的结果
array_multisort($arr_title, SORT_ASC, $arr_age, SORT_DESC, $arr);// 函数中每个数组参数后面都可以加两个选项,是升/降序,按照数字/字符排序的选项 print_r($arr);
这里对比一下usort()函数的使用:
print_r($arr);
usort($arr, 'mysort');
function mysort($v1, $v2){
if($v1['title'] > $v2['title']){
return 1;
} else if ($v1['title'] < $v2['title']){
return -1;
} else { // 如果title相同,则比较age
if($v1['age'] > $v2['age']){
return -1;
} else if ($v1['age'] < $v2['age']){
return 1;
}
return 0;
}
}
print_r($arr);
显然可以看出array_multisort()在对比这种多维数组的情况下更简洁。
接着上面的例子,又given一个case,比如说我希望按照age排序,但是我要指定一个顺序,而不是按照age数字的大小。
比如age按照32->27->30->31的顺序来排。
稍微有点经验的程序员就知道应该做一个映射,把这个指定的年龄顺序,映射一个有序的参照数组。
代码如下:
// 指定年龄顺序,映射一个有序的排序
$map = array(
32 => 'a',
27 => 'b',
30 => 'c',
31 => 'd',
);
$arr_age = array();// 这个就是参照数组
foreach($arr as $val){
$arr_age[] = $map[$val['age']];
}
array_multisort($arr_age, $arr);// 搞定
再举两个例子,这里就直接粘贴下手册里的两个例子,要好好理解,当然最后还是知道该什么时候用这个函数,怎么用它更高效了哈哈。

===============================

array_multisort函数,以及多维数组下排序的应用,并与usort函数对比的更多相关文章
- PHP数组函数 array_multisort() ----对多个数组或多维数组进行排序
PHP中array_multisort可以用来一次对多个数组进行排序,或者根据某一维或多维对多维数组进行排序. 关联(string)键名保持不变,但数字键名会被重新索引. 输入数组被当成一个表的列并以 ...
- PHP array_multisort—对多个数组或多维数组进行排序
PHP中array_multisort可以用来一次对多个数组进行排序,或者根据某一维或多维对多维数组进行排序. 关联(string)键名保持不变,但数字键名会被重新索引. 输入数组被当成一个表的列并以 ...
- array_multisort—对多个数组或多维数组进行排序
From: http://www.cnblogs.com/lwbqqyumidi/archive/2013/01/31/2887188.html PHP中array_multisort可以用来一次对多 ...
- 代码分享:php对二维数组进行排序
发布:net/PHP编程 编辑:thebaby 2013-06-28 13:12:54 [大 中 小] 转自:http://www.jbxue.com/article/9991.html本文介 ...
- php 根据指定的键对多维数组进行排序
根据指定的键对多维数组排序,可以按照多个键排序 我们通常有一些多维数组需要排序: $guys = array( array( 'name' => 'jake', 'score' => 80 ...
- php 二维数组自定义排序
eg1:只根据一个规则进行排序,比如我下面的数组是一组满减折扣的信息,我要按照满减的金额从小到大排序 代码: <?php $arr =[ ["amount"=> 60, ...
- php二维数组中的查找(善于利用基础函数)
php二维数组中的查找(善于利用基础函数) 一.总结 真没必要完整的写函数,善于借用 1.array_search()是在以为数组中来找,现在我们要在二维数组数组中来,肯定要借用这个 2.!==fal ...
- java中二维数组的排序
首先定义一个5X8的二维数组,然后使用随机数填充满.借助Arrays的方法对二维数组进行排序.参考思路:先把二维数组使用System.arraycopy进行数组复制到一个一维数组然后使用sort进行排 ...
- [C++ Primer Plus] 第7章、函数(一)程序清单——递归,指针和const,指针数组和数组指针,函数和二维数组
程序清单7.6 #include<iostream> using namespace std; ; int sum_arr(int arr[], int n);//函数声明 void ma ...
随机推荐
- SSM 后台封装的有值, 到前台打印的时候没有值
原因: 实体类中的getting setting 方法没有配置,导致封装json 数据的时候没有封装进去
- 【代码笔记】iOS-键盘自适应弹出
一,效果图. 二,工程图. 三,代码. ViewController.h #import <UIKit/UIKit.h> @interface ViewController : UIVie ...
- [Ubuntu] 14.04 外接显示器分辨率调整
最近按照提示更新了一下系统,安装了100多M的更新包,结果系统又读不出外接显示器的信息了,开机显示vga-1:probed a monitor but no|invalid edid,我也不懂. 后来 ...
- UWP开发细节记录:IStream 和 IRandomAccessStream^ 以及 IMFByteStream 互转
IStream 和 IRandomAccessStream^ 互转 IRandomAccessStream^ --> IStream: CreateStreamOverRandomAccess ...
- LeetCode 题解之Add Digits
1.问题描述 2.问题分析 循环拆分数字,然求和判断. 3.代码 int addDigits(int num) { ) return num; int result = num; do{ vector ...
- SQL SERVER 2012/ 2014 分页,用 OFFSET,FETCH NEXT改写ROW_NUMBER的用法(转)
写法: 假装有个表Shop,其中有一列ShopName,取100000到100050条数据. ROW_NUMBER 的写法 SELECT * FROM (SELECT ShopName , ROW_N ...
- Linux 基本概念 & 命令
0. Linux 理解 Linux 是一种操作系统,主要应用于服务器. Linux 性能稳定,其中的许多版本不收费(如CentOS),占用资源较少. 1. 命令行的状态 在 Linux 命令行下以上分 ...
- MySQL基础之---mysqlimport工具和LOAD DATA命令导入文本文件
1.mysqlimport工具的使用 看一下命令的使用方法: shell > mysqlimport -u root -p [--LOCAL] DBname File [option] --f ...
- 每年有20万人进军IT行业,为何还会人才短缺?
众所周知,IT行业是个高薪行业,也是很多人的梦想职业,在全球最缺人的十大行业中IT行业居首位. 但是现在很多人都有一个疑问: 几乎每所大学里都有计算机技术相关专业,再加上IT培训机构的输出,每年培养出 ...
- leetcode 121 买卖股票的最佳时机
题目 给定一个数组,它的第 i 个元素是一支给定股票第 i 天的价格. 如果你最多只允许完成一笔交易(即买入和卖出一支股票),设计一个算法来计算你所能获取的最大利润. 注意你不能在买入股票前卖出股票. ...