根据内部数组的值对PHP多维数组进行排序?

28

我正在尝试按照内部数组中特定的值对PHP哈希表进行排序。数据结构如下:

print_r($mydata);

Array(
[0] => Array
    (
        [type] => suite
        [name] => A-Name
    )
[1] => Array
    (
        [type] => suite
        [name] => C-Name
    )
[2] => Array
    (
        [type] => suite
        [name] => B-Name
    )
)

我尝试过 ksortsortusort,但似乎都没用。我想根据两个级别下的 名称键 进行排序。

以下是我使用 usort 的尝试:

function cmp($a, $b) {
    return $b['name'] - $a['name'];
}

usort($mydata, "cmp");

有没有简单的方法可以做到这一点,还是我需要编写自定义排序函数?


那么你如何尝试使用usort? - Mark Baker
我在问题中添加了我的代码。 - user1216398
从一个字符串中减去另一个字符串?难怪它不起作用,你有没有看过phpdocs网页上的例子?http://www.php.net/manual/en/function.usort.php——特别是第二个例子。 - Mark Baker
6个回答

78

思考,更有用和实用的内容 http://php.net/manual/zh/function.sort.php

function array_sort($array, $on, $order=SORT_ASC){

    $new_array = array();
    $sortable_array = array();

    if (count($array) > 0) {
        foreach ($array as $k => $v) {
            if (is_array($v)) {
                foreach ($v as $k2 => $v2) {
                    if ($k2 == $on) {
                        $sortable_array[$k] = $v2;
                    }
                }
            } else {
                $sortable_array[$k] = $v;
            }
        }

        switch ($order) {
            case SORT_ASC:
                asort($sortable_array);
                break;
            case SORT_DESC:
                arsort($sortable_array);
                break;
        }

        foreach ($sortable_array as $k => $v) {
            $new_array[$k] = $array[$k];
        }
    }

    return $new_array;
}

如何使用

 $list = array(
   array( 'type' => 'suite', 'name'=>'A-Name'),
   array( 'type' => 'suite', 'name'=>'C-Name'),
   array( 'type' => 'suite', 'name'=>'B-Name')
 );

$list = array_sort($list, 'name', SORT_ASC);

array(3) { [0]=> array(2) { ["type"]=> string(5) "suite" ["name"]=> string(6) "A-Name"    } [2]=> array(2) { ["type"]=> string(5) "suite" ["name"]=> string(6) "B-Name" } [1]=> array(2) { ["type"]=> string(5) "suite" ["name"]=> string(6) "C-Name" } }

9
那是一个过于复杂的解决方案。 - deceze
1
@deceze 你好!感谢您的评论和点踩。您能证明一下您的观点吗?提前致谢。 - voodoo417
21
“usort($mydata, function ($a, $b) { return strcmp($a['name'], $b['name']); })”这句代码已经可以正常运作,所以我认为你的代码过于复杂了。 - deceze
  1. 对于这样一个简短的一行代码,写一些通用的东西并不是非常必要,几乎无法与MVC基础设施相比较。
  2. 即使对于一个通用函数来说,这也相当复杂;请参见https://stackoverflow.com/a/22829326/476。
- deceze
@deceze 我看了你的链接..... ))) 你让我开心了一整天。附言:好的,我明白了。谢谢你给我带来了一整天的好心情))). - voodoo417
显示剩余5条评论

13

尝试使用这个usort函数:

    function cmp($a, $b){
        if ($a == $b)
            return 0;
        return ($a['name'] < $b['name']) ? -1 : 1;
    }

$my_array = array(
0 => array
    (
        'type' => 'suite'
        ,'name' => 'A-Name'
    )
,1 => array
    (
        'type' => 'suite'
        ,'name' => 'C-Name'
    )
,2 => array
    (
        'type' => 'suite'
        ,'name' => 'B-Name'
    )
);


usort($my_array, "cmp");
如果您在类中使用它,则第二个参数将更改为以下数组:
usort($my_array, array($this,'cmp'));

非常好,谢谢。 - B3none
uasort($my_array, function ($a, $b){ if ($a == $b) return 0; return ($a['name'] < $b['name']) ? -1 : 1; }); - vikash

3

这个视频比 PHP 手册更友好:http://www.youtube.com/watch?v=zBaHBmZLDxY - Kamil

1
 <?php
$a=array(
array('a'=>5,'b'=>7),array('c'=>4,'d'=>2),array('e'=>0,'f'=>12)

    );
function cmp_sort($x,$y){           //your function to compare two keys
if($x===$y)
    return 0;
else
    return ($x<$y?1:-1);
}

uasort($a,'cmp_sort');    //call user-defined compare function
print_r($a);              //printing the sorted array


?>

输出=>

数组([2] => 数组([e] => 0 [f] => 12)[1] => 数组([c] => 4 [d] => 2)[0] => 数组([a] => 5 [b] => 7))


0
$this->aasort($array,"key");

function aasort (&$array, $key) {
    $sorter=array();
    $ret=array();
    reset($array);

    foreach ($array as $ii => $va) {
        $sorter[]=$va[$key];
    }

    arsort($sorter);

    foreach ($sorter as $ii => $va) {
        $ret[]=$array[$ii];
    }

    return $array=$ret;
}

0

尝试使用这个递归模式,我在Magento REST API中使用过:

$parameters = ['searchCriteria' => ['currentPage' => 1, 'pageSize' => 20]];
$parameters['searchCriteria']['filter_groups'][0]['filters'][0] = ['condition_type' => 'from', 'field' => 'updated_at', 'value' => '2017-01-01T00:00:00'];
$parameters['searchCriteria']['filter_groups'][1]['filters'][0] = ['condition_type' => 'to', 'field' => 'updated_at', 'value' => '2017-12-31T23:59:59']; 

function sortArrayByKeyAsc($_params){
    if(is_array($_params)){
        uksort($_params, 'strnatcmp');
        foreach ($_params as $key => $value){
            if(is_array($value)){
                $_params[$key] = sortArrayByKeyAsc($value);
            }
        }
    }
    return $_params;
}

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接