按多个字段值对 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中文网其他相关文章!