php - 如何在PHP中对多维数组中的多维数组进行排序
问题描述
我无法解决这个问题。我几乎什么都试过。
我正在做一个包含歌曲艺术家及其歌曲数据库的家庭项目,但我偶然发现了一个我无法解决的大问题。我阅读了大多数 stackoverflow 帖子,但没有任何帮助。我用关于 php 排序方法的问题轰炸了谷歌并尝试了它们,但没有成功。
我真的很感激帮助。我被困在这个问题上已经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")
)
)
)
);
我希望,我的问题很清楚。我是新来的,我还不是所有按钮的真正朋友。我等不及了,希望能解决这个问题...
解决方案
使用array_walk()和usort()。array_walk()
是对数组进行迭代,usort()
是按顺序对歌曲进行ASC
排序DESC
。
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
});
推荐阅读
- reactjs - 首次上传后 FineUploader 不工作
- python - 将一个df中的每一列除以Python中另一个df中的每一列
- java - 运行 jre keytool 导致 Permission Denied 错误
- django - 使用 Amazon Redshift 对使用 Postgresql 作为数据库的 Django 应用程序进行分析
- ios - 如何将相机指向 iOS 11 以下的 SCNVector3 点
- reactjs - 如何使用 React 获取查询字符串?
- c# - 在 asp net 中传递大字符串并使用 json 获得答案
- javascript - 当我使用 HTML Drag and Drop API 时,draggable 不起作用
- java - 计算 am*n 矩阵中的连接数
- .htaccess - 使用 htaccess 将子目录直接指向子域