使用 array_multisort() 对多维 PHP 数组进行不区分大小写排序


Case Insensitively Sort a Multidimensional PHP Array using array_multisort()

经过大量搜索,我无法找到有关如何使用array_multisort()按一个字段对多维数组进行大小写不区分的良好解释。我发现在处理来自数据库查询的信息时,这是一个非常有用的功能,所以我想我会分享。

我应该注意这仅适用于 php 5.4+

# Example results from database
$PDOresult = array(
    array('name' => 'Alpha', 'price' => '10'),
    array('name' => 'beta', 'price' => '12'),
    array('name' => 'Gamma', 'price' => '14'),
    array('name' => 'delta', 'price' => '16'),
    array('name' => 'Epsilon', 'price' => '18'),
    array('name' => 'zeta', 'price' => '20'),
    ...
);
# Create array of field to sort by - 'name' in this example
foreach ($PDOresult as $key => $row) {
    $sort_by[$key] = $row['name'];
}
# Sort array - The flags SORT_NATURAL & SORT_FLAG_CASE are required to make the
# sorting case insensitive.
array_multisort($sort_by, SORT_ASC, SORT_NATURAL|SORT_FLAG_CASE, $PDOresult);
# Output
var_dump($PDOresult);

如果使用 php 5.5+,您可以跳过foreach()而改用 array_column()。这样:

$sort_by = array_column($PDOresult, 'name');

我很想把它编辑成写得很好的答案:如何在 PHP 中对数组和数据进行排序? 但我不想搞砸格式,所以如果有人想这样做并关闭它,那对我来说很好。

@damndaewoo

SORT_ASC|SORT_NATURAL|SORT_FLAG_CASE

在某些情况下会给你:

Warning: array_multisort(): Argument #2 is an unknown sort flag 

正如文档在这里所说,您应该使用","而不是"|"但是您不能执行以下操作:

SORT_ASC,SORT_NATURAL,SORT_FLAG_CASE 因为你会得到一个意想不到的:

Argument #4 is expected to be an array or sorting flag that has not already been specified

相反,您将使用以下两种技术:

array_multisort($sort_by, SORT_ASC,SORT_NATURAL|SORT_FLAG_CASE, $PDOresult);

您也可以简单地这样做:

foreach ($PDOresult as $key => $row) {
    $sort_by[$key] = strtolower($row['name']);
}
array_multisort($sort_by, SORT_ASC, $PDOresult);

不需要特殊标志,因为排序依据的所有内容都是小写的。如果您担心 UTF-8,请改用 mb_strtolower()。这将具有与带有特殊标志的解决方案相同的结果,但在我看来更直观。