php сортирует многомерный массив по ключу - PullRequest
0 голосов
/ 22 октября 2019

У меня есть такой массив:

    $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 голосов
/ 22 октября 2019

Измените свою функцию на

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_DESC ИЛИ SORT_ASC

Рабочий пример: - https://3v4l.org/pQ0Eu

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...