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 ...
随机推荐
- Angular 中引入BootStrap
由于Bootstrap官方目前并没有发布Angular的相关类库进行支持,当前Angular只能引用使用Bootstrap相关的样式.无法使用Bootstrap自带的脚本逻辑.以下以Angular7和 ...
- element-ui 中的table的列隐藏问题
element-ui 中的table和bootstrap中的table的某些设置还是有一定的差别的.之前用bootstrap做的表格,想要实现简短列和详细列的切换.因为详细列实在有太多列了,拉动滚动条 ...
- 如何在Oracle数据库中查看哪些用户在执行哪些SQL
对于DBA来说,这是一个非常常见的问题,DBA需要找出以下问题: 1.哪些用户在跑哪些SQL? 2.一个特定的SQL是被哪个用户在执行? 3.一个特定的用户在跑哪些SQL? 从这些问题中可以很明显的看 ...
- C#与java中的AES加解密互解算法
一.C#版AES加解密算法 public class AESCode { public string Key { get; set; } public string Encrypt(string va ...
- 多个Portal for ArcGIS 间的协作实操
原理 协作Colabartion 通过类似握手协议的方式在多个Portal之间建立信任关系.一个协作由一个宿主Portal和多个受邀Portal组成. 工作空间Workspace 一个协作可包含多个工 ...
- ebook
libgen.io onlybooks.org www.ebook3000.com www.foxebook.net
- 如何将水晶报表(Crystal Report)导入葡萄城报表
当从旧的报表平台迁移到葡萄城报表工具时,意味着有大量的报表设计工作要重复去做,如果有一款工具能够在这些工具之间进行自由转换,就能省去报表开发几乎一半的工作量. 葡萄城报表为兼容其他报表控件,提供了简单 ...
- 网络基础 HTTP协议之HTTP消息(HTTP Message)
HTTP协议之HTTP消息(HTTP Message) by:授客 QQ:1033553122 1. 消息类型(Message Type) HTTP messages包含从客户端到服务器的请求和服 ...
- Android--listView的divider分割线样式和边距
1.建立一个drawable文件list_divider.xml <?xml version="1.0" encoding="utf-8"?> &l ...
- JBoss 7 里一个EJB依赖其他jar的几种方式
JBoss 7 与之前的版本有了巨大的变化,最核心的类的加载方式变了,有点类似OSGI那样搞起来了分模块的类加载方式,而不是以前的分层类加载.按以前的类加载方式,在加载树底下的那些类,总是能看到父节点 ...