PHP实现二维数组按照指定的字段进行排序算法示例
本文实例讲述了PHP实现二维数组按照指定的字段进行排序算法。分享给大家供大家参考,具体如下:
遇到问题:把两个数组用php自带的array_merge()
函数合并之后,想按照两个数组中共有的’post_time’字段为新数组进行排序
解决办法:通过查阅官方手册,得知有array_multisort()
这个函数,可以对多个数组或多维数组进行排序,返回排序之后的数组,其中字符串键名将被保留,但是数字键名将被重新索引,从 0 开始,并以 1 递增。
下面封装了这个函数,便于调用:
/**
* 二维数组按照指定字段进行排序
* @params array $array 需要排序的数组
* @params string $field 排序的字段
* @params string $sort 排序顺序标志 SORT_DESC 降序;SORT_ASC 升序
*/
function arraySequence($array, $field, $sort = 'SORT_DESC') {
$arrSort = array();
foreach ($array as $uniqid = $row) {
foreach ($row as $key = $value) {
$arrSort[$key][$uniqid] = $value;
}
}
array_multisort($arrSort[$field], constant($sort), $array);
return $array;
}
//测试:
$arrDemo = array(
array('name'= 'Jack','age'= '22'),
array('name'= 'Tom','age'= '24'),
array('name'= 'Green','age'= '21'),
array('name'= 'Ben','age'= '23'),);
$arrDemo = arraySequence($arrDemo,'age');
print_r($arrDemo);
运行结果:
Array ( [0] = Array ( [name] = Tom [age] = 24 ) [1] = Array ( [name] = Ben [age] = 23 ) [2] = Array ( [name] = Jack [age] = 22 ) [3] = Array ( [name] = Green [age] = 21 ) )
新增:按照指定的多个字段排序
/**
* 二维数组按照指定的多个字段进行排序
*
* 调用示例:sortArrByManyField($arr,'id',SORT_ASC,'age',SORT_DESC);
*/
function sortArrByManyField(){
$args = func_get_args();
if(empty($args)){
return null;
}
$arr = array_shift($args);
if(!is_array($arr)){
throw new Exception("第一个参数应为数组");
}
foreach($args as $key = $field){
if(is_string($field)){
$temp = array();
foreach($arr as $index= $val){
$temp[$index] = $val[$field];
}
$args[$key] = $temp;
}
}
$args[] = &$arr;//引用值
call_user_func_array('array_multisort',$args);
return array_pop($args);
}
//测试:
$arrDemo = array(
array('name'= 'Jack','age'= '22'),
array('name'= 'Tom','age'= '24'),
array('name'= 'Green','age'= '21'),
array('name'= 'Ben','age'= '23'),);
$arrDemo = sortArrByManyField($arrDemo,'age');
print_r($arrDemo);
运行结果:
Array ( [0] = Array ( [name] = Green [age] = 21 ) [1] = Array ( [name] = Jack [age] = 22 ) [2] = Array ( [name] = Ben [age] = 23 ) [3] = Array ( [name] = Tom [age] = 24 ) )
PS:这里再为大家推荐一款关于排序的演示工具供大家参考:
在线动画演示插入/选择/冒泡/归并/希尔/快速排序算法过程工具: http://tools.zalou.cn/aideddesign/paixu_ys
- Spring Cloud Edgware新特性之八:Zuul回退的改进
- Install Django Nginx uWSGI
- Spring Cloud Edgware新特性之七:可选的EnableDiscoveryClient注解
- 【LEETCODE】模拟面试-46. Permutations
- CentOS6 Upgrade Python
- Emacs setup for Go Development
- 【LEETCODE】模拟面试-39. Combination Sum
- Docker系列教程12-使用Maven插件构建Docker镜像
- Linux nohup 用法
- 【LEETCODE】模拟面试-84-Largest Rectangle in Histogram
- Docker系列教程11-使用Nexus管理Docker镜像
- Mac 配置终端环境
- 【LEETCODE】模拟面试-101-Symmetric Tree
- Docker系列教程10-使用Docker Registry管理镜像
- php概述
- php教程
- php环境搭建
- PHP书写格式
- php变量
- php常量
- PHP注释
- php数组
- php字符串 string
- PHP整型 integer
- PHP浮点型 float
- php布尔型
- php数据类型之数组
- php数据类型之对象
- php数据类型之null
- php数据类型之间的转换
- php运算符
- php表达式
- PHP循环控制
- PHP流程控制
- php函数
- php全局变量
- PHP魔术变量
- php命名空间
- php 日期
- PHP包含文件
- php文件
- PHP 文件上传
- php Cookies
- php Sessions
- php email
- php安全email
- php错误处理
- PHP异常处理
- php过滤器
- PHP 高级过滤器
- php json
- php 表单
- PHP MySQL 简介
- PHP 连接 MySQL
- php创建数据库
- php 创建表
- php mysq 插入数据
- PHP MySQL 插入多条数据
- PHP MySQL 预处理语句
- php mysql 读取数据
- php mysql where
- PHP MySQL Order By
- PHP MySQL Update
- PHP MySQL Delete
- php ODBC
- Hello!GitHub 好用好玩值得收藏的开源项目集合~
- 【一起学系列】之工厂模式:产品?产品族?
- 再见,Navicat!同事安利的这个IDEA的兄弟,真香!
- 【一起学系列】之单例模式:只推荐三种~
- 【一起学系列】之命令模式:封装一个简单Jedis?
- 轻松学Pytorch-实现自定义对象检测器
- Elasticsearch 升级 7.x 版本后,我感觉掉坑里了!
- 【一起学系列】之适配器模式:还有外观模式呢
- 【翻译】200行代码讲透RUST FUTURES (5)
- Unable to preventDefault inside passive event listener
- js 停止事件冒泡 阻止浏览器的默认行为(阻止a标签跳转 )
- EmitMapper的使用小结
- js .map方法
- 【一起学系列】之模板方法:写SSO我只要5分钟
- ConcurrentDictionary线程不安全么,你难道没疑惑,你难道弄懂了么?