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 ...
随机推荐
- @NotNull、@NotEmpty、@NotBlank的区别
Spring中@NotNull.@NotEmpty.@NotBlank的区别@NotNull:用于基本数据类型@NotEmpty:用于集合类@NotBlank:用于String上面
- Spring Boot系列学习文章(一) -- Intellij IDEA 搭建Spring Boot项目
前言: 最近做的一个项目是用Spring Boot来做的,所以把工作中遇到的一些知识点.问题点整理一下,做成一系列学习文章,供后续学习Spring Boot的同仁们参考,我也是第一次接触Spring ...
- Python实现屏幕截图的两种方式
Python实现屏幕截图的两种方式 使用windows API 使用PIL中的ImageGrab模块 下面对两者的特点和用法进行详细解释. 一.Python调用windows API实现屏幕截图 好处 ...
- MiUI开发者版刷入xposed框架--简洁方法
一,首先要确定手机是否解锁 可以去这里查看怎么解锁: http://www.miui.com/unlock/index.html 二,手机系统需要是开发者版,且在安全中心的授权管理打开了ROOT授权 ...
- SQL Server 2000中的并行处理和执行计划中的位图运算符
SQL Server 2000中的并行处理和执行计划中的位图运算符 摘抄自:SQLServer 2000并行处理和位图简介 刘志斌 并行查询介绍Degree of Parallelism(并行度) 一 ...
- mysql Alter table设置default的问题,是bug么?
不用不知道,用了没用? 昨天在线上创建了一个表,其中有两个列是timestamp类型的,创建语句假设是这样的: create table timetest(id int, createtime tim ...
- ETL技巧应用(高级应用介绍:准备区运用、 时间戳的运用、日志表的运用、使用调度)
1.1 准备区运用 a.在构建数据仓库时,数据源位于一服务器上,数据仓库在另一服务器端,数据源Server端访问频繁,并且数据量大,需要不断更新, b.建立准备区数据库: >将数据抽取到准 ...
- 关于ORA-00257: archiver error. Connect internal only, until freed 错误处理方法
产生原因:出现ORA-00257错误(空间不足错误),通过查找资料,绝大部分说这是由于归档日志太多,占用了全部的硬盘剩余空间导致的,通过简单删除日志或加大存储空间就能够解决 解决办法:(亲测有效) 1 ...
- 一、Ajax 二、JSON数据格式 三、Ajax+Jquery 四、分页的实现
一.Ajax概述###<1>概述 ###<2>组成 以XMLHttpRequest为核心,发送Ajax请求和接收处理结果 以javascript为语言基础 以XML/JSON作 ...
- set集合综合案例
案例01:生成0-10之间5个不相等的数 方法1:使用list集合实现 import random list01 = [] for i in range(100): num01 = random.ra ...