2024-05-03

在 PHP 中,如何根据数组值的比较对数组进行排序?

php 中对数组进行排序的方法有:使用 sort() 函数升序排列。使用 rsort() 函数降序排列。使用 asort() 函数为关联数组升序排列值。使用 arsort() 函数为关联数组降序排列值。使用自定义比较函数进行更复杂的排序。

在 PHP 中,如何根据数组值的比较对数组进行排序?

如何根据数组值的比较对 PHP 数组进行排序

在 PHP 中,有多种方法可以根据数组值的比较对数组进行排序。本文将介绍使用内置函数 sort()rsort()asort()arsort() 和自定义比较函数对数组进行排序的常见方法。

使用 sort() 函数:

sort() 函数对数组中的值进行从小到大的升序排列。

$arr = [3, 5, 2, 7, 1];
sort($arr);
print_r($arr); // 输出: [1, 2, 3, 5, 7]
登录后复制

使用 rsort() 函数:

rsort() 函数对数组中的值进行从大到小的降序排列。

$arr = [3, 5, 2, 7, 1];
rsort($arr);
print_r($arr); // 输出: [7, 5, 3, 2, 1]
登录后复制

使用 asort() 函数:

asort() 函数对关联数组中的值进行从小到大的升序排列,键保持不变。

$arr = [
    "name" => "John",
    "age" => 30,
    "city" => "New York"
];
asort($arr);
print_r($arr); 
// 输出: [
//     "age" => 30,
//     "city" => "New York",
//     "name" => "John"
// ]
登录后复制

使用 arsort() 函数:

arsort() 函数对关联数组中的值进行从大到小的降序排列,键保持不变。

$arr = [
    "name" => "John",
    "age" => 30,
    "city" => "New York"
];
arsort($arr);
print_r($arr); 
// 输出: [
//     "name" => "John",
//     "city" => "New York",
//     "age" => 30
// ]
登录后复制

使用自定义比较函数:

对于更复杂的排序要求,可以使用自定义比较函数。比较函数接受两个参数,并返回 -1、0 或 1,具体取决于第一个参数是否小于、等于或大于第二个参数。

function custom_sort($a, $b) {
    return strcmp($a["name"], $b["name"]);
}

$arr = [
    ["name" => "John", "age" => 30],
    ["name" => "Mary", "age" => 25],
    ["name" => "Bob", "age" => 35]
];
usort($arr, "custom_sort");
print_r($arr); 
// 输出: [
//     ["name" => "Bob", "age" => 35],
//     ["name" => "John", "age" => 30],
//     ["name" => "Mary", "age" => 25]
// ]
登录后复制

实战案例:

以下是一个实战案例,展示了如何使用 sort() 函数对电子游戏角色的数组按名称进行升序排序:

$characters = [
    ["name" => "Mario", "level" => 5],
    ["name" => "Luigi", "level" => 3],
    ["name" => "Donkey Kong", "level" => 7]
];

sort($characters);
print_r($characters); 
// 输出: [
//     ["name" => "Donkey Kong", "level" => 7],
//     ["name" => "Luigi", "level" => 3],
//     ["name" => "Mario", "level" => 5]
// ]
登录后复制

以上就是在 PHP 中,如何根据数组值的比较对数组进行排序?的详细内容,更多请关注php中文网其它相关文章!

https://www.php.cn/faq/774945.html

发表回复

Your email address will not be published. Required fields are marked *