使用php将二位数组按照第二维的指定元素的值进行排序,array_multisort和array_column结合使用

使用php将二位数组按照第二维的指定元素的值进行排序

原数组

//原始数组是这样的,希望能够按照第二维中的run_date升序或者降序进行排序:
$arr=array(
                0=>array(
                    'run_date'=>'2017-11-21',
                    'count'=>'5'
                ),
                1=>array(
                    'run_date'=>'2017-11-20',
                    'count'=>'10'
                ),
                2=>array(
                    'run_date'=>'2017-11-22',
                    'count'=>'10'
                )
            );
//希望得到:
$arr=array(
                0=>array(
                    'run_date'=>'2017-11-20',
                    'count'=>'5'
                ),
                1=>array(
                    'run_date'=>'2017-11-21',
                    'count'=>'10'
                ),
                2=>array(
                    'run_date'=>'2017-11-22',
                    'count'=>'10'
                )
);

实现方法

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

array_column 、 array_multisort

还是上面的数组:

//先用array_column 多维数组按照纵向(列)取出

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

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

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

array_multisort($date,SORT_ASC,$arr);

//最终的结果:
$arr=array(
                0=>array(
                    'run_date'=>'2017-11-20',
                    'count'=>'5'
                ),
                1=>array(
                    'run_date'=>'2017-11-21',
                    'count'=>'10'
                ),
                2=>array(
                    'run_date'=>'2017-11-22',
                    'count'=>'10'
                )
            );

函数说明

1、array_column 获取数组中的某一个元素形成一个新的数组

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即可

样例

<?php


$qipa250_list = array(
    '0' => array(
        'name' => '小程序',
        'value' => 10,
    ),
    '1' => array(
        'name' => '朋友圈',
        'value' => 100,
    ),
    '2' => array(
        'name' => '搜索',
        'value' => 90,
    ),
);

echo "原qipa250_list<pre>";
print_r($qipa250_list);


$value = array_column($qipa250_list, 'value');

array_multisort($value,SORT_DESC,$qipa250_list);



echo "新qipa250_list<pre>";
print_r($qipa250_list);


?>

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值