PHP Сортировка массива по значению SubArray
У меня есть следующая структура массива:
Array
(
[0] => Array
(
[configuration_id] => 10
[id] => 1
[optionNumber] => 3
[optionActive] => 1
[lastUpdated] => 2010-03-17 15:44:12
)
[1] => Array
(
[configuration_id] => 9
[id] => 1
[optionNumber] => 2
[optionActive] => 1
[lastUpdated] => 2010-03-17 15:44:12
)
[2] => Array
(
[configuration_id] => 8
[id] => 1
[optionNumber] => 1
[optionActive] => 1
[lastUpdated] => 2010-03-17 15:44:12
)
)
Каков наилучший способ упорядочить массив в пошаговом режиме, основываясь на optionNumber
?
Итак, результаты выглядят так:
Array
(
[0] => Array
(
[configuration_id] => 8
[id] => 1
[optionNumber] => 1
[optionActive] => 1
[lastUpdated] => 2010-03-17 15:44:12
)
[1] => Array
(
[configuration_id] => 9
[id] => 1
[optionNumber] => 2
[optionActive] => 1
[lastUpdated] => 2010-03-17 15:44:12
)
[2] => Array
(
[configuration_id] => 10
[id] => 1
[optionNumber] => 3
[optionActive] => 1
[lastUpdated] => 2010-03-17 15:44:12
)
)
Ответы
Ответ 1
Используйте usort
.
function cmp_by_optionNumber($a, $b) {
return $a["optionNumber"] - $b["optionNumber"];
}
...
usort($array, "cmp_by_optionNumber");
В PHP ≥5.3 вместо анонимная функция:
usort($array, function ($a, $b) {
return $a['optionNumber'] - $b['optionNumber'];
});
Обратите внимание, что оба вышеуказанных кода предполагают, что $a['optionNumber']
является целым числом. Используйте @St. John Johnson, если они являются строками.
В PHP ≥7.0 вместо <вычитания > используйте оператор космического корабля <=>
, чтобы предотвратить проблемы с переполнением/усечением.
usort($array, function ($a, $b) {
return $a['optionNumber'] <=> $b['optionNumber'];
});
Ответ 2
Используйте usort
usort($array, 'sortByOption');
function sortByOption($a, $b) {
return strcmp($a['optionNumber'], $b['optionNumber']);
}
Ответ 3
Я использовал оба решения KennyTM и AJ Quick и придумал функцию, которая может помочь в этом вопросе во многих случаях, таких как использование сортировки ASC или DESC или сохранение ключей, или если у вас есть объекты в качестве дочерних элементов массива.
Вот эта функция (работает для PHP7 и выше из-за оператора космического корабля):
/**
* @param array $array
* @param string $value
* @param bool $asc - ASC (true) or DESC (false) sorting
* @param bool $preserveKeys
* @return array
* */
function sortBySubValue($array, $value, $asc = true, $preserveKeys = false)
{
if ($preserveKeys) {
$c = [];
if (is_object(reset($array))) {
foreach ($array as $k => $v) {
$b[$k] = strtolower($v->$value);
}
} else {
foreach ($array as $k => $v) {
$b[$k] = strtolower($v[$value]);
}
}
$asc ? asort($b) : arsort($b);
foreach ($b as $k => $v) {
$c[$k] = $array[$k];
}
$array = $c;
} else {
if (is_object(reset($array))) {
usort($array, function ($a, $b) use ($value, $asc) {
return $a->{$value} == $b->{$value} ? 0 : ($a->{$value} <=> $b->{$value}) * ($asc ? 1 : -1);
});
} else {
usort($array, function ($a, $b) use ($value, $asc) {
return $a[$value] == $b[$value] ? 0 : ($a[$value] <=> $b[$value]) * ($asc ? 1 : -1);
});
}
}
return $array;
}
Использование:
sortBySubValue($array, 'optionNumber', true, false);
редактировать
Первая часть может быть переписана с помощью uasort()
и функция будет короче (работает для PHP7 и выше из-за оператора космического корабля):
/**
* @param array $array
* @param string $value
* @param bool $asc - ASC (true) or DESC (false) sorting
* @param bool $preserveKeys
* @return array
* */
function sortBySubValue($array, $value, $asc = true, $preserveKeys = false)
{
if (is_object(reset($array))) {
$preserveKeys ? uasort($array, function ($a, $b) use ($value, $asc) {
return $a->{$value} == $b->{$value} ? 0 : ($a->{$value} <=> $b->{$value}) * ($asc ? 1 : -1);
}) : usort($array, function ($a, $b) use ($value, $asc) {
return $a->{$value} == $b->{$value} ? 0 : ($a->{$value} <=> $b->{$value}) * ($asc ? 1 : -1);
});
} else {
$preserveKeys ? uasort($array, function ($a, $b) use ($value, $asc) {
return $a[$value] == $b[$value] ? 0 : ($a[$value] <=> $b[$value]) * ($asc ? 1 : -1);
}) : usort($array, function ($a, $b) use ($value, $asc) {
return $a[$value] == $b[$value] ? 0 : ($a[$value] <=> $b[$value]) * ($asc ? 1 : -1);
});
}
return $array;
}
Ответ 4
Клавиши удаляются при использовании функции, аналогичной приведенной выше. Если ключи важны, следующая функция будет поддерживать его... но петли foreach довольно неэффективны.
function subval_sort($a,$subkey) {
foreach($a as $k=>$v) {
$b[$k] = strtolower($v[$subkey]);
}
asort($b);
foreach($b as $key=>$val) {
$c[$key] = $a[$key];
}
return $c;
}
$array = subval_sort($array,'optionNumber');
Используйте arsort вместо asort, если хотите от максимума до минимума.
Кодовый кредит: http://www.firsttube.com/read/sorting-a-multi-dimensional-array-with-php/
Ответ 5
PHP 5.3 +
usort($array, function($a,$b){ return $a['optionNumber']-$b['optionNumber'];} );
Ответ 6
Использование array_multisort(), array_map()
array_multisort(array_map(function($element) {
return $element['optionNumber'];
}, $array), SORT_ASC, $array);
print_r($array);
DEMO