繁体   English   中英

如何在PHP中对多维数组中的多维数组进行排序

[英]How to sort a multidimensional array in a multidimensional array in PHP

我无法解决此问题。 我几乎尝试了所有事情。

我正在使用歌曲艺术家及其歌曲数据库进行家庭项目,但偶然发现了一个我无法解决的大问题。 我阅读了大多数stackoverflow帖子,但没有帮助。 我用有关php排序方法的问题轰炸了google,并尝试了它们,但没有成功。

我非常感谢您的帮助。 我已经坚持了三天了...

这是我的问题:

我现在与艺术家($ arr)一起演奏数组,如何按年份对每个艺术家的每个歌曲数组进行排序? 数据来自.json文件

$arr = array(
    "artists" => array(
        "1" => array(
            "id" => "1",
            "firstname" => "John",
            "lastname" => "Doe",
            "songs" => array(
                array("name" => "song_1", "year" => "1999"),
                array("name" => "song_2", "year" => "1987")
            ),
        ),
        "2" => array(
            "id" => "2",
            "firstname" => "Jane",
            "lastname" => "Doe",
            "songs" => array(
                array("name" => "song_1", "year" => "2000"),
                array("name" => "song_2", "year" => "1999")
            )
        ),
        "3" => array(
            "id" => "3",
            "firstname" => "Mark",
            "lastname" => "Doe",
            "songs" => array(
                array("name" => "song_1", "year" => "1984"),
                array("name" => "song_2", "year" => "1983")
            )
        )
    )
);

希望我的问题很清楚。 我是新来的人,但并不是所有按钮的朋友。 我迫不及待地希望解决这个问题...

使用array_walk()usort() array_walk()用于对数组进行迭代,而usort()用于按ASCDESC顺序对歌曲进行排序。

array_walk($arr['artists'], function (&$song) {
    usort($song['songs'], function ($a, $b) { return $a['year'] > $b['year'] ? 1 : -1; }); // Ascending order
    //usort($song['songs'], function ($a, $b) { return $a['year'] < $b['year'] ? 1 : -1; }); // Descending order
});

演示版

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM