给定此数组:
Array
(
[0] => Array
(
[status] => closed
[userModifiedAt] => 2015-12-09T11:47:46Z
)
[1] => Array
(
[status] => active
[userModifiedAt] => 2016-02-08T16:43:26Z
)
[2] => Array
(
[status] => closed
[userModifiedAt] => 2016-03-31T03:47:19Z
)
[3] => Array
(
[status] => pending
[userModifiedAt] => 2015-12-08T14:09:58Z
)
我想按[状态]订购,订单如下:-挂起-活动的-关闭
对于每个状态,按[userModifiedAt]排序。
我使用的是这个代码:
usort($array, function($a,$b){ return strcmp($a['status'], $b['status']);} );
但它按字母顺序工作,因此状态按如下顺序排列:-活动的-已关闭-待处理
如何根据预定义的顺序列表对数组进行排序?
这将是一个技巧-
## A array with the orders to be considered
$order = array('active' => 1, 'closed' => 2, 'pending' => 3);
usort($array, function($a, $b) use($order) { // Use the order array to compare
return $order[$a[status]] - $order[$b[status]];
});
var_dump($array);
输出
array(4) {
[0]=>
array(2) {
["status"]=>
string(6) "active"
["userModifiedAt"]=>
string(20) "2016-02-08T16:43:26Z"
}
[1]=>
array(2) {
["status"]=>
string(6) "closed"
["userModifiedAt"]=>
string(20) "2015-12-09T11:47:46Z"
}
[2]=>
array(2) {
["status"]=>
string(6) "closed"
["userModifiedAt"]=>
string(20) "2016-03-31T03:47:19Z"
}
[3]=>
array(2) {
["status"]=>
string(7) "pending"
["userModifiedAt"]=>
string(20) "2015-12-08T14:09:58Z"
}
}
如果您想要不同的订单,请更改订单array
。具有最低值的键将位于array
上的第一个。如果您希望关闭是第一个,则在$order
数组中为其提供最低值。
演示