给定此数组:
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
数组中为其提供最小值。
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句