首页 >后端开发 >php教程 >如何按多个字段值对 PHP 数组进行排序?

如何按多个字段值对 PHP 数组进行排序?

Patricia Arquette
Patricia Arquette原创
2024-12-15 05:26:12878浏览

How to Sort a PHP Array by Multiple Field Values?

按多个字段值对 PHP 数组进行排序

在 PHP 中对具有多个值的数组进行排序可能很棘手,但有几种方法可以实现此目的。一种常见的解决方案是使用 array_multisort() 函数。

假设您有一个类似于问题中提供的数组:

Array ([
        [
            'destination' => 'Sydney',
            'airlines' => 'airline_1',
            'one_way_fare' => 100,
            'return_fare' => 300,
        ],
        [
            'destination' => 'Sydney',
            'airlines' => 'airline_2',
            'one_way_fare' => 150,
            'return_fare' => 350,
        ],
        [
            'destination' => 'Sydney',
            'airlines' => 'airline_3',
            'one_way_fare' => 180,
            'return_fare' => 380,
        ],
    ]
)

要按 return_fare 和 one_way_fare 对此数组进行排序升序,您可以使用 array_multisort() 如下:

// Obtain a list of columns
foreach ($data as $key => $row) {
    $return_fare[$key]  = $row['return_fare'];
    $one_way_fare[$key] = $row['one_way_fare'];
}

// Sort the data with return_fare descending, one_way_fare ascending
array_multisort($data, $return_fare, SORT_ASC, $one_way_fare, SORT_ASC);

这将对数组进行排序

另一种选择是使用 array_orderby() 函数,它提供了按多个条件排序的简化语法:

$sorted = array_orderby($data, 'return_fare', SORT_ASC, 'one_way_fare', SORT_ASC);

为了避免循环,您还可以使用 array_column() (PHP 5.5.0 中提供)或更高版本)提取所需的列,然后对这些列使用 array_multisort():

array_multisort(
    array_column($data, 'return_fare'), SORT_ASC,
    array_column($data, 'one_way_fare'), SORT_ASC,
    $data
);

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

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