我有一个类似于下面的数组,但它可能包含更多草稿。
$multi_arr = array(
'draft1' => array (
'alloc_coeff' => 560,
'steps_count' => 2,
'order_draft' => array(
'0' => array(
'whse_id' => 4,
'quantity' => 0,
'percent' => 0
),
'1' => array(
'whse_id' => 1,
'quantity' => 10,
'percent' => 66.666666666667
)
)
),
'draft2' => array (
'alloc_coeff' => 1517,
'steps_count' => 1,
'order_draft' => array(
'0' => array(
'whse_id' => 1,
'quantity' => 10,
'percent' => 66.666666666667
)
)
),
'draft3' => array (
'alloc_coeff' => 559,
'steps_count' => 2,
'order_draft' => array(
'0' => array(
'whse_id' => 2,
'quantity' => 0,
'percent' => 0
),
'1' => array(
'whse_id' => 1,
'quantity' => 10,
'percent' => 66.666666666667
)
)
)
);
我需要使用两个变量对内容进行排序:alloc_coeff
和steps_count
。
首先需要从最高值到最低值考虑alloc_coeff
。
然后作为第二个变量steps_count
从最低值到最高值。
usort($multi_arr, function($a, $b) {
return $a['alloc_coeff'] <=> $b['alloc_coeff'];
});
我不需要重写整个数组并存储在临时变量中,我只需要像这样排序的键(预期结果)draft2
,draft1
,最后{{1} }。
有什么方法可以实现这个目标?
答案 0 :(得分:1)
你可以这样做: -
array_multisort(array_column($multi_arr, 'alloc_coeff'), SORT_DESC,
array_column($multi_arr, 'steps_count'), SORT_ASC,
$multi_arr);
输出: - https://eval.in/924894和https://eval.in/924892
注意: - 在5.6.23和PHP 7.0.8中测试