如何按值对多维数组进行排序

新手上路,请多包涵

如何按“order”键的值对该数组进行排序?

尽管这些值当前是连续的,但它们并不总是如此。

 Array
(
    [0] => Array
        (
            [hashtag] => a7e87329b5eab8578f4f1098a152d6f4
            [title] => Flower
            [order] => 3
        )

    [1] => Array
        (
            [hashtag] => b24ce0cd392a5b0b8dedc66c25213594
            [title] => Free
            [order] => 2
        )

    [2] => Array
        (
            [hashtag] => e7d31fc0602fb2ede144d18cdffd816b
            [title] => Ready
            [order] => 1
        )
)

原文由 stef 发布,翻译遵循 CC BY-SA 4.0 许可协议

阅读 360
2 个回答

尝试一个 usort 。如果您仍在使用 PHP 5.2 或更早版本,则必须先定义一个排序函数:

 function sortByOrder($a, $b) {
    return $a['order'] - $b['order'];
}

usort($myArray, 'sortByOrder');

从 PHP 5.3 开始,您可以使用匿名函数:

 usort($myArray, function($a, $b) {
    return $a['order'] - $b['order'];
});

使用 PHP 7,您可以使用 spaceship 运算符

 usort($myArray, function($a, $b) {
    return $a['order'] <=> $b['order'];
});

最后,在 PHP 7.4 中,您可以使用箭头函数进行一些清理:

 usort($myArray, fn($a, $b) => $a['order'] <=> $b['order']);

要将其扩展到多维排序,如果第一个排序元素为零,请参考第二个/第三个排序元素 - 最好在下面解释。您也可以使用它对子元素进行排序。

 usort($myArray, function($a, $b) {
    $retval = $a['order'] <=> $b['order'];
    if ($retval == 0) {
        $retval = $a['suborder'] <=> $b['suborder'];
        if ($retval == 0) {
            $retval = $a['details']['subsuborder'] <=> $b['details']['subsuborder'];
        }
    }
    return $retval;
});

如果您需要保留键关联,请使用 uasort() - 请参阅手册 中的数组排序功能比较

原文由 Christian Studer 发布,翻译遵循 CC BY-SA 4.0 许可协议

正如接受的答案所述,您可以使用:

 usort($myArray, function($a, $b) {
    return $a['order'] <=> $b['order'];
});

如果您需要按多列排序,那么您将执行以下操作:

 usort($myArray, function($a, $b) {
    return [$a['column1'],$a['column2']] <=> [$b['column1'],$b['column2']];
});

这可以扩展到数据中的任意数量的列。这取决于您可以在 PHP 中直接比较数组这一事实。在上面的示例中,数组将首先按 column1 排序,然后按 column2 排序。但是您可以按任何顺序按列排序,例如:

 usort($myArray, function($a, $b) {
    return [$a['column2'],$a['column1']] <=> [$b['column2'],$b['column1']];
});

如果您需要对一列升序和另一列降序进行排序,则将降序列交换到运算符的另一侧 <=>

 usort($myArray, function($a, $b) {
    return [$a['column1'],$b['column2']] <=> [$b['column1'],$a['column2']];
});

原文由 Guillermo Phillips 发布,翻译遵循 CC BY-SA 4.0 许可协议

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题