php - php sort multidimensional array by key
问题描述
I have array like this:
$arr = [];
$arr['cat1']=[
'attributes'=>[
[
'attributeName'=>'name1',
'attrSortOrder'=>'1'
],
[
'attributeName'=>'name2',
'attrSortOrder'=>'5'
],
[
'attributeName'=>'name3',
'attrSortOrder'=>'2'
],
],
'category_id'=>10
];
$arr['cat2']=[
'attributes'=>[
[
'attributeName'=>'name4',
'attrSortOrder'=>'5'
],
[
'attributeName'=>'name5',
'attrSortOrder'=>'7'
],
[
'attributeName'=>'name6',
'attrSortOrder'=>'2'
],
],
'category_id'=>12
];
I need for each $arr element sort 'attributes' by attrSortOrder column. I tried it:
function array_sort_by_column(&$arr, $col, $dir = SORT_ASC) {
$sort_col = array();
foreach ($arr as $key=> $row) {
$sort_col[$key] = strtolower($row[$col]);
}
array_multisort($sort_col, $dir, $arr);
}
array_sort_by_column($arr,'attrSortOrder');
But it did not help me. How can solve this? How can i sort my array correctly? Thanks.
解决方案
Change your function to
function array_sort_by_column(&$arr, $col, $dir = SORT_DESC) {
foreach($arr as &$v){//pass by reference each sub-array
array_multisort(array_column($v['attributes'], 'attrSortOrder'), $dir, $v['attributes']);
}
}
array_sort_by_column($arr,'attrSortOrder');
You can change second argument SORT_DESC
OR SORT_ASC
Working example :- https://3v4l.org/pQ0Eu
推荐阅读
- python - 如何将前 4 个列表值划分为数据框 pandas 中的列
- git - 无法在 Gitea 上使用 Git LFS 推送大文件
- excel - VBA Excel“对象变量或未设置块变量”
- python - 在 MATLAB 和 Python 中重塑和索引
- html - 对于任何屏幕分辨率,如何将一张图像相对于另一张图像设置?
- java - 在 Java 中阻塞 main 方法总是不好的吗?
- mongodb - 关于 mongodb 副本集性能的一般问题
- node.js - type-graphql 实体如何从 JSON.stringify 中省略字段?
- php - 这是哪种类型的黑客攻击?从不存在的 URL 访问不存在的 shell 文件
- connect-by - Oracle 分层查询