请选择 进入手机版 | 继续访问电脑版

人人商城开发

 找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

搜索
热搜: 活动 交友 discuz
查看: 339|回复: 0

PHP将二位数组按照第二维的某个元素的值进行排序

[复制链接]

67

主题

87

帖子

640

积分

超级版主

Rank: 8Rank: 8

积分
640
发表于 2018-10-19 16:05:05 | 显示全部楼层 |阅读模式
本帖最后由 hamt 于 2018-10-19 16:07 编辑

复制代码

  1. //原始数组是这样的,希望能够按照第二维中的run_date升序或者降序进行排序:
  2. $arr=array(
  3.                 0=>array(
  4.                     'run_date'=>'2017-11-21',
  5.                     'count'=>'5'
  6.                 ),
  7.                 1=>array(
  8.                     'run_date'=>'2017-11-20',
  9.                     'count'=>'10'
  10.                 ),
  11.                 2=>array(
  12.                     'run_date'=>'2017-11-22',
  13.                     'count'=>'10'
  14.                 )
  15.             );
  16. //希望得到:
  17. $arr=array(
  18.                 0=>array(
  19.                     'run_date'=>'2017-11-20',
  20.                     'count'=>'5'
  21.                 ),
  22.                 1=>array(
  23.                     'run_date'=>'2017-11-21',
  24.                     'count'=>'10'
  25.                 ),
  26.                 2=>array(
  27.                     'run_date'=>'2017-11-22',
  28.                     'count'=>'10'
  29.                 )
  30. );
复制代码


当然,用循环遍历是可以解决的,但是还是觉得效率有点低,这里有另外一个解决方案,是使用两个PHP提供的函数:
array_column   、    array_multisort

还是上面的数组:
  1. //先用array_column 多维数组按照纵向(列)取出

  2. $date = array_column($arr, 'run_date');

  3. //上面得到的结果:array(0=>'2017-11-21',1=>'2017-11-20',3=>'2017-11-22')

  4. //再用array_multisort  结合array_column得到的结果对$arr进行排序

  5. array_multisort($date,SORT_ASC,$arr);

  6. //最终的结果:
  7. $arr=array(
  8.                 0=>array(
  9.                     'run_date'=>'2017-11-20',
  10.                     'count'=>'5'
  11.                 ),
  12.                 1=>array(
  13.                     'run_date'=>'2017-11-21',
  14.                     'count'=>'10'
  15.                 ),
  16.                 2=>array(
  17.                     'run_date'=>'2017-11-22',
  18.                     'count'=>'10'
  19.                 )
  20.             );
复制代码
附:
1、array_column 参考我之前的博客 http://www.cnblogs.com/Steven-shi/p/5897745.html
2、array_multisort array_multisort() 函数对多个数组或多维数组进行排序,可以用来一次对多个PHP二维数组排序进行排序,或者根据某一维或多维对多维数组进行排序
参数中的数组被当成一个表的列并以行来进行排序 - 这类似 SQL 的 ORDER BY 子句的功能。第一个数组是要排序的主要数组。数组中的行(值)比较为相同的话,就会按照下一个输入数组中相应值的大小进行排序,依此类推。
第一个参数是数组,随后的每一个参数可能是数组,也可能是下面的排序顺序标志(排序标志用于更改默认的排列顺序)之一:
SORT_ASC - 默认,按升序排列。(A-Z)
SORT_DESC - 按降序排列。(Z-A)
随后可以指定排序的类型:
SORT_REGULAR - 默认。将每一项按常规顺序排列。
SORT_NUMERIC - 将每一项按数字顺序排列。
SORT_STRING - 将每一项按字母顺序排列。
array_multisort(array1,sorting order,sorting type,array2,array3...)
array1 : 必需。规定输入的数组。
sorting order : 可选。规定排列顺序。可能的值是 SORT_ASC 和 SORT_DESC。
sorting type : 可选。规定排序类型。可能的值是SORT_REGULAR、SORT_NUMERIC和SORT_STRING。
array2 : 可选。规定输入的数组。
array3 : 可选。规定输入的数组。
注释:字符串键名将被保留,但是数字键将被重新索引,从 0 开始,并以 1 递增。
注释:您可以在每个数组后设置排序顺序和排序类型。如果没有设置,每个数组参数会使用默认值。
PHP二维数组排序是按照第一个数组进行排序,并且调整后面的顺序。像这样的数组:
array( 'id' => array(1,3,2), 'data'=>array('a','c','b'))
只要按照id进行多维排序,就可以了。但是很多时候,我们构造出的数组是这样的:
array( array('id'=>1,'data'=>'a'), array('id'=>3,'data'=>'c'), array('id'=>2,'data'=>'b') );
PHP二维数组排序的元素是按行排列的,需要按其中的一列进行排序。PHP好像也没提供类似矩阵转置的函数,所以不能直接使用array_multisort进行多维排序。不过只需要先把排序的列抽取出来,作为第一个参数传给array_multisort即可

回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

Archiver|手机版|小黑屋|人人商城开发

GMT+8, 2020-1-20 11:32 , Processed in 0.080018 second(s), 27 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表