【问题标题】:How to sort a multidimensional array in a multidimensional array in PHP如何在PHP中对多维数组中的多维数组进行排序
【发布时间】:2019-11-26 23:35:11
【问题描述】:

我无法解决这个问题。我几乎什么都试过了。

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

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

这是我的问题:

我现在有我的艺术家 ($arr) 数组,我如何按 year 对每个 artist 的每个 song 数组进行排序?数据来自 .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")
            )
        )
    )
);

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

【问题讨论】:

  • 到目前为止你尝试了什么?即使它不起作用,也要展示你迄今为止尝试过的东西。
  • 如果它来自数据库,那么你可以做order by year ASC(同时获取歌曲数组)

标签: php sorting arraylist multidimensional-array array-multisort


【解决方案1】:

使用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
});

Demo

【讨论】:

  • 您的代码对找到解决方案非常有帮助,但我真的不明白您实际上做了什么...如果您能以非常通俗的方式描述您的代码,它将对我未来的编程很有帮助简洁版本。例如:第一行的&-sing是什么意思array_walk($arr['artists'], function (&amp;$song) {...
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2016-09-27
  • 1970-01-01
相关资源
最近更新 更多