首页 >后端开发 >php教程 >如何在 PHP 中按多列对多维数组进行排序?

如何在 PHP 中按多列对多维数组进行排序?

Barbara Streisand
Barbara Streisand原创
2024-12-17 14:07:10376浏览

How Can I Sort a Multidimensional Array by Multiple Columns in PHP?

按多列对多维数组进行排序

按多列对多维数组进行排序可能是一项具有挑战性的任务。然而,PHP 提供了一系列函数,使其相对简单。

其中一个函数是 array_multisort()。此函数允许您同时按多个条件对数组进行排序。要使用 array_multisort(),您必须首先创建一个排序列及其相应数据的数组。

这里是一个示例:

<?php
$mylist = array(
    array('ID' => 1, 'title' => 'Boring Meeting', 'date_start' => '2010-07-30', 'event_type' => 'meeting', 'state' => 'new-york'),
    array('ID' => 2, 'title' => 'Find My Stapler', 'date_start' => '2010-07-22', 'event_type' => 'meeting', 'state' => 'new-york'),
    array('ID' => 3, 'title' => 'Mario Party', 'date_start' => '2010-07-22', 'event_type' => 'party', 'state' => 'new-york'),
    array('ID' => 4, 'title' => 'Duct Tape Party', 'date_start' => '2010-07-28', 'event_type' => 'party', 'state' => 'california')
);

# get a list of sort columns and their data to pass to array_multisort
$sort = array();
foreach($mylist as $k => $v) {
    $sort['state'][$k] = $v['state'];
    $sort['event_type'][$k] = $v['event_type'];
    $sort['date_start'][$k] = $v['date_start'];
}

# sort by state asc, event_type desc, and date_start asc
array_multisort($sort['state'], SORT_ASC, $sort['event_type'], SORT_DESC, $sort['date_start'], SORT_ASC, $mylist);

print_r($mylist); // print the sorted array

?php>

从 PHP 5.5.0 开始,您可以使用以下简化语法:

<?php
array_multisort(array_column($mylist, 'state'), SORT_ASC,
                array_column($mylist, 'event_type'), SORT_DESC,
                array_column($mylist, 'date_start'), SORT_ASC,
                $mylist);
?php>

$mylist 数组现在将按所需的指定列进行排序订购。

以上是如何在 PHP 中按多列对多维数组进行排序?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn