PHP实现二维数组按某列进行排序的方法


Posted in PHP onNovember 18, 2016

本文实例讲述了PHP实现二维数组按某列进行排序的方法。分享给大家供大家参考,具体如下:

/*
* 二维数组 按某列排序
* array_multisort($arr1,$arr2)
* 手册 例子如下
*
*/
$data[] = array('volume' => 67, 'edition' => 2);
$data[] = array('volume' => 86, 'edition' => 1);
$data[] = array('volume' => 85, 'edition' => 6);
$data[] = array('volume' => 98, 'edition' => 2);
$data[] = array('volume' => 86, 'edition' => 6);
$data[] = array('volume' => 67, 'edition' => 7);
// 取得列的列表
foreach ($data as $key => $row) {
  $volume[$key] = $row['volume'];
  $edition[$key] = $row['edition'];
}
// 将数据根据 volume 降序排列,根据 edition 升序排列
// 把 $data 作为最后一个参数,以通用键排序
array_multisort($volume, SORT_DESC, $edition, SORT_ASC, $data);
/*************************************/
/* 从上面的例子不难看出,array_multisort()函数
* 是将每一个二维数组的列作为 一个参数进行排序
* 来达到整个数组的排序
*/
/*************************************/
function sigcol_arrsort($data,$col,$type=SORT_DESC){
  if(is_array($data)){
    $i=0;
    foreach($data as $k=>$v){
      if(key_exists($col,$v)){
        $arr[$i] = $v[$col];
        $i++;
      }else{
        continue;
      }
    }
  }else{
    return false;
  }
  array_multisort($arr,$type,$data);
  return $data;
}
print_r(sigcol_arrsort($data,'edition',SORT_DESC));
/*说白了 原理就是:
新数组  原二维数组
 2    array('volume' => 67, 'edition' => 2);
 1    array('volume' => 86, 'edition' => 1);
 6    array('volume' => 85, 'edition' => 6);
 2    array('volume' => 98, 'edition' => 2);
 6    array('volume' => 86, 'edition' => 6);
 7    array('volume' => 67, 'edition' => 7);
这两个数组的每一行都锁在一起,新数组一旦变动顺序,
那么就会连带每一行的二维数组也跟着变换顺序 ,即新数组为参照物
相当于查询子句中的 order by
*/

运行结果:

Array
(
  [0] => Array
    (
      [volume] => 67
      [edition] => 7
    )
  [1] => Array
    (
      [volume] => 85
      [edition] => 6
    )
  [2] => Array
    (
      [volume] => 86
      [edition] => 6
    )
  [3] => Array
    (
      [volume] => 67
      [edition] => 2
    )
  [4] => Array
    (
      [volume] => 98
      [edition] => 2
    )
  [5] => Array
    (
      [volume] => 86
      [edition] => 1
    )
)

希望本文所述对大家PHP程序设计有所帮助。

PHP 相关文章推荐
一个MYSQL操作类
Nov 16 PHP
检查php文件中是否含有bom的函数
May 31 PHP
跟我学Laravel之安装Laravel
Oct 15 PHP
PHP开启opcache提升代码性能
Apr 26 PHP
orm获取关联表里的属性值
Apr 17 PHP
php使用curl通过代理获取数据的实现方法
May 16 PHP
php+flash+jQuery多图片上传源码分享
Jul 27 PHP
利用PHP生成静态html页面的原理
Sep 30 PHP
PHP基于自增数据如何生成不重复的随机数示例
May 19 PHP
PHP实现的pdo连接数据库并插入数据功能简单示例
Mar 30 PHP
PHP设计模式之观察者模式定义与用法分析
Apr 04 PHP
laravel框架分组控制器和分组路由实现方法示例
Jan 25 PHP
PHP二维数组去重实例分析
Nov 18 #PHP
浅谈php fopen下载远程文件的函数
Nov 18 #PHP
PHP实现的自定义数组排序函数与排序类示例
Nov 18 #PHP
php array_walk 对数组中的每个元素应用用户自定义函数详解
Nov 18 #PHP
PHP屏蔽关键字实现方法
Nov 17 #PHP
php实现背景图上添加圆形logo图标的方法
Nov 17 #PHP
PHP解压ZIP文件到指定文件夹的方法
Nov 17 #PHP
You might like
jQuery+PHP+ajax实现微博加载更多内容列表功能
2014/06/27 PHP
PHP设置images目录不充许http访问的方法
2016/11/01 PHP
PHP用mysql_insert_id()函数获得刚插入数据或当前发布文章的ID
2016/11/25 PHP
Sample script that displays all of the users in a given SQL Server DB
2007/06/16 Javascript
js用Date对象处理时间实现思路及代码
2013/01/31 Javascript
js中单引号与双引号冲突问题解决方法
2013/10/04 Javascript
JS匀速运动演示示例代码
2013/11/26 Javascript
页面js遇到乱码问题的解决方法是和无法转码的情况
2014/04/30 Javascript
纯Javascript实现ping功能的方法
2015/03/20 Javascript
AspNet中使用JQuery上传插件Uploadify详解
2015/05/20 Javascript
干货分享:让你分分钟学会javascript闭包
2015/12/25 Javascript
jQuery插件WebUploader实现文件上传
2016/11/07 Javascript
Javascript 链式作用域详细介绍
2017/02/23 Javascript
jQuery实现遍历XML节点和属性的方法示例
2018/04/29 jQuery
Nodejs文件上传、监听上传进度的代码
2020/03/27 NodeJs
[51:15]2014 DOTA2国际邀请赛中国区预选赛 Orenda VS LGD-GAMING
2014/05/22 DOTA
Pandas 对Dataframe结构排序的实现方法
2018/04/10 Python
详解Python 协程的详细用法使用和例子
2018/06/15 Python
在python中只选取列表中某一纵列的方法
2018/11/28 Python
python使用pip安装SciPy、SymPy、matplotlib教程
2019/11/20 Python
Python操作Sqlite正确实现方法解析
2020/02/05 Python
python super函数使用方法详解
2020/02/14 Python
浅析两列自适应布局的3种思路
2016/05/03 HTML / CSS
墨西哥网上超市:Superama
2018/07/10 全球购物
英国排名第一的礼品体验公司:Red Letter Days
2018/08/16 全球购物
高中学生期末评语
2014/04/25 职场文书
学习雷锋演讲稿
2014/05/10 职场文书
无刑事犯罪记录证明范本
2014/09/29 职场文书
党的群众路线教育实践活动个人对照检查材料(四风)
2014/11/05 职场文书
自我检讨书范文
2015/01/28 职场文书
药店营业员岗位职责
2015/04/14 职场文书
2015年行政执法工作总结
2015/05/23 职场文书
人与自然的观后感
2015/06/18 职场文书
乡镇司法所2015年度工作总结
2015/10/14 职场文书
积极心理学课程心得体会
2016/01/22 职场文书
Go Grpc Gateway兼容HTTP协议文档自动生成网关
2022/06/16 Golang