PHP:根据值列表对多维数组进行排序


PHP: order a multi-dimensional array according to a list of values

给定此数组:

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数组中为其提供最低值。

演示