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

我无法解决这个问题。我几乎尝试了一切。


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


我真的很感激帮助。我现在坚持了3天......


这是我的问题:


我有我的艺术家 ($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")

            )

        )

    )

);

我希望,我的问题已经足够清楚了。我是新来的,我还不是所有按钮的真正朋友。我等不及了,希望能解决这个问题......


临摹微笑
浏览 147回答 1
1回答

慕斯王

使用array_walk()和usort()。array_walk()是对数组进行迭代,并按或顺序usort()对歌曲进行排序。ASCDESCarray_walk($arr['artists'], function (&$song) {&nbsp; &nbsp; usort($song['songs'], function ($a, $b) { return $a['year'] > $b['year'] ? 1 : -1; }); // Ascending order&nbsp; &nbsp; //usort($song['songs'], function ($a, $b) { return $a['year'] < $b['year'] ? 1 : -1; }); // Descending order});
打开App,查看更多内容
随时随地看视频慕课网APP