首页 >后端开发 >php教程 >如何在 PHP 中按特定列值对关联数组进行排序?

如何在 PHP 中按特定列值对关联数组进行排序?

Patricia Arquette
Patricia Arquette原创
2024-12-17 10:25:25297浏览

How Can I Sort an Associative Array by a Specific Column Value in PHP?

按列值对关联数组进行排序

给定一个关联数组数组,任务是根据特定列对元素进行排序价值。例如,考虑以下数组:

$inventory = array(
  array("type" => "fruit", "price" => 3.50),
  array("type" => "milk", "price" => 2.90),
  array("type" => "pork", "price" => 5.43),
);

目标是按“价格”列对 $inventory 进行排序,结果是:

$inventory = array(
  array("type" => "pork", "price" => 5.43),
  array("type" => "fruit", "price" => 3.50),
  array("type" => "milk", "price" => 2.90),
);

使用 array_multisort( )

为了实现这一点,我们可以使用 array_multisort() 函数。它允许按多列对多个数组进行排序。

这是一个示例:

$price = array();
foreach ($inventory as $key => $row) {
    $price[$key] = $row['price'];
}
array_multisort($price, SORT_DESC, $inventory);

或者,使用 array_column() (自 PHP 5.5.0 起可用):

$price = array_column($inventory, 'price');
array_multisort($price, SORT_DESC, $inventory);

通过对 $price 数组进行排序,我们间接对 $inventory 进行排序,因为它们共享相同的内容钥匙。

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

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