php按键对多维数组进行排序

时间:2019-10-22 08:31:29

标签: php arrays sorting

我有这样的数组:

    $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
    ];

我需要为每个$ arr元素按 attrSortOrder 列对属性进行“归类”。 我试过了:

  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');

但这并没有帮助我。怎么解决呢?我如何正确排序我的数组? 谢谢。

1 个答案:

答案 0 :(得分:0)

将功能更改为

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');

您可以更改第二个参数SORT_DESCSORT_ASC

工作示例:-https://3v4l.org/pQ0Eu

相关问题