按多列对多维数组进行排序
对多维数组进行排序可能是一项具有挑战性的任务,尤其是在考虑多个条件时。幸运的是,PHP 提供了 array_multisort 函数形式的优雅解决方案。
要对多维数组进行排序,我们需要提取所需的列并将它们传递给 array_multisort。每列独立排序,排序顺序指定为 SORT_ASC 或 SORT_DESC。
例如,给定以下输入数组:
$array = [ ['ID' => 1, 'title' => 'Boring Meeting', 'date_start' => '2010-07-30', 'event_type' => 'meeting', 'state' => 'new-york'], ['ID' => 2, 'title' => 'Find My Stapler', 'date_start' => '2010-07-22', 'event_type' => 'meeting', 'state' => 'new-york'], ['ID' => 3, 'title' => 'Mario Party', 'date_start' => '2010-07-22', 'event_type' => 'party', 'state' => 'new-york'], ['ID' => 4, 'title' => 'Duct Tape Party', 'date_start' => '2010-07-28', 'event_type' => 'party', 'state' => 'california'] ];
按 state 排序,然后按 event_type 排序,最后按 event_type 排序date_start,我们将使用以下代码:
# extract columns $state = array_column($array, 'state'); $event_type = array_column($array, 'event_type'); $date_start = array_column($array, 'date_start'); # sort by state desc, event_type asc, date_start asc array_multisort($state, SORT_DESC, $event_type, SORT_ASC, $date_start, SORT_ASC, $array);
PHP 5.5.0 引入了一个简化的语法,使用array_column:
array_multisort( array_column($array, 'state'), SORT_DESC, array_column($array, 'event_type'), SORT_ASC, $array );
排序后的数组如下所示:
[ ['ID' => 4, 'title' => 'Duct Tape Party', 'date_start' => '2010-07-28', 'event_type' => 'party', 'state' => 'california'], ['ID' => 3, 'title' => 'Mario Party', 'date_start' => '2010-07-22', 'event_type' => 'party', 'state' => 'new-york'], ['ID' => 2, 'title' => 'Find My Stapler', 'date_start' => '2010-07-22', 'event_type' => 'meeting', 'state' => 'new-york'], ['ID' => 1, 'title' => 'Boring Meeting', 'date_start' => '2010-07-30', 'event_type' => 'meeting', 'state' => 'new-york'], ];
通过利用 array_multisort,我们可以有效地根据多列对多维数组进行排序,提供了灵活而强大的排序方法数据组织和检索的解决方案。
以上是如何使用'array_multisort”按多列对 PHP 中的多维数组进行排序?的详细内容。更多信息请关注PHP中文网其他相关文章!