PHP сортировка многомерных массивов - PullRequest
5 голосов
/ 06 августа 2010

У меня есть следующий массив. Мне нужно отсортировать этот массив по ключу вложенного массива [id]:

Array ( 
[0] => Array ( [id] => 5 [category_id] => 12 )
[1] => Array ( [id] => 3 [category_id] => 12 )
[2] => Array ( [id] => 9 [category_id] => 12 )
[3] => Array ( [id] => 4 [category_id] => 12 )
)

Ответы [ 6 ]

8 голосов
/ 06 августа 2010

Используйте usort с пользовательской функцией сравнения.

<?php

function cmp($a, $b) {
  if ($a['id'] == $b['id'])
    return 0;
  return $a['id'] < $b['id'] ? -1 : 1;
}

$array = Array ( 
  0 => Array ( 'id' => 5, 'category_id' => 12 ),
  1 => Array ( 'id' => 4, 'category_id' => 12 ),
  2 => Array ( 'id' => 7, 'category_id' => 12 ),
  3 => Array ( 'id' => 3, 'category_id' => 12 ),
);

usort($array, 'cmp');

// Output: 3 4 5 7 
foreach ($array as $element)
   echo $element['id'], " ";
2 голосов
/ 06 августа 2010

вы можете сделать это так

foreach($arr as $val) {
    $ret[$val['id']] = $val['category_id'];
}
ksort($ret);

Если вы хотите отсортировать тот же массив, вы можете добавить следующий код:

foreach($ret as $key=>$val) {
    $newArr[] = array('id'=>$key,'category_id'=>$val);
}
2 голосов
/ 06 августа 2010

Возможно, вы захотите использовать array_multisort Посмотрите на пример № 3 в документации.

1 голос
/ 06 августа 2010

Почему бы просто не сохранить данные таким образом?

Array ( 
    [5] => int(12)
    [3] => int(12)
    [9] => int(12)
    [4] => int(12)
)

Тогда вы можете просто использовать ksort () как обычно.

0 голосов
/ 06 августа 2010
function sort_by_field($field, & $data) {
    $sort_func = create_function('$a,$b', 'if ($a["' . $field . '"] == $b["' . $field . '"]) {return 0;} 
            return ($a["' . $field . '"] < $b["' . $field . '"]) ? -1 : 1;');

    uasort($data, $sort_func);
}
0 голосов
/ 06 августа 2010

try array_multisort сортирует внешний массив по первому ключу / свойству внутренних массивов

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