PHP 一个多维数组排序的问题
这个问题有点类似 Mysql 中 order by ,需要的就是在数组中模拟对不同字段的排序。
假如有以下数组:
$beforeSort = [
"0" => ["name" => "张三", "english" => 80, "chinese" => 60, "math" => 50 ],
"1" => ["name" => "李四", "english" => 50, "chinese" => 60, "math" => 70 ],
"2" => ["name" => "老王", "english" => 30, "chinese" => 50, "math" => 80 ],
];
现在需要在数组中按照 chinese
顺序,假如有相同,就按 math
顺序,最后得到的应该是如下的数组:
$afterSort = [
"2" => ["name" => "老王", "english" => 30, "chinese" => 50, "math" => 80 ],
"0" => ["name" => "张三", "english" => 80, "chinese" => 60, "math" => 50 ],
"1" => ["name" => "李四", "english" => 50, "chinese" => 60, "math" => 70 ],
];
请问大家有什么不同的方法可以实现?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(9)
这是我自己使用的版本,使用方法:
打印结果:
可以将数组转为集合,再处理。使用php的集合实现的sort方法,专治各种复杂排序
<?php
//现在需要在数组中按照 chinese 顺序,假如有相同,就按 math 顺序,最后得到的应该是如下的数组:
$beforeSort = [
];
$data_math = array_column($beforeSort,'math');
$data_chinese = array_column($beforeSort,'chinese');
array_multisort($data_chinese,SORT_ASC,$data_math,SORT_ASC,$beforeSort);
print_r($beforeSort);
///借用楼上哥们答案
对多维数组排序,官方有一个函数可以实现 array_multisort
$beforeSort = [
];
foreach ($beforeSort as $key => $value) {
}
array_multisort($chinese, SORT_ASC, $math, SORT_ASC, $beforeSort);
print_r($beforeSort);