Рассмотрим следующий ассоциативный массив
$arr = Array
(
[banana] => 2
[cherry] => 1
[orange] => 3
[grapefruit] => 1
[apple] => 1
)
Я хочу отсортировать его таким образом, который был бы похож на PLSQL-термины: A DESC, B ASC
(где A - значение, а B - ключ), что означает:
$arr = Array
(
[orange] => 3
[banana] => 2
[apple] => 1
[cherry] => 1
[grapefruit] => 1
)
чтобы апельсин и банан были первыми из-за VALUE, но тогда у меня есть яблоко, вишня и грейпфрут в алфавитном порядке, потому что они имеют одинаковое значение VALUE.
Что я пробовал:
1. для запуска ksort(), а затем asort()/rsort(), надеясь, что второй сорт поднимется оранжевым и бананом до начала массива, не испортив алфавитный вид других 3 предметов. Я был неправ. это все испортит. Итак, я проверил:
2. функции сортировки и array_multisort(). Но, по-видимому, он сортирует сразу несколько массивов или многомерный массив.
3. Я также попытался определить следующую функцию сравнения:
function cmp($a, $b)
{
foreach ($a as $key1 => $val1) {
foreach ($b as $key2 => $val2) {
if($val1 == $val2){
return strcmp($key1,$key2);
}
else if ($val1 > $val2){
return 1;
}
else{ // $val1 < $val2
return -1;
}
}
}
}
и назовите его usort(), но он также не работает.
Итак, мой вопрос: есть ли метод PHP, который реализует запрошенное поведение?
Для Eugen:
Я попробовал, и он не работает
перед сортировкой:
Array
(
[lamb] => 3
[rule] => 1
[children] => 1
[teacher] => 2
[eager] => 1
)
и после сортировки:
Array
(
[children] => 1
[eager] => 1
[rule] => 1
[teacher] => 2
[lamb] => 3
)