PHP数组排序需根据需求选择函数:sort()/rsort()用于简单升/降序但重置键;asort()/arsort()按值排序且保留键值关联;ksort()/krsort()按键排序;usort()/uasort()/uksort()支持自定义规则,其中uasort()和uksort()可保留键值对关系。

PHP对数组进行排序提供了非常丰富的内置函数,无论是简单的升降序、按键排序,还是复杂的自定义规则,你总能找到合适的工具。核心在于理解你的排序需求:是只关心值,还是键值对都要保留?是按数字还是按字母?
当你面对一堆数据,想给它们排个序,PHP真是提供了不少趁手的工具。这里我直接列举一些最常用的,以及它们各自的脾气秉性。
sort()
和
rsort()
:最直接的数值排序
sort()
:对数组进行升序排列,但要注意,它会重置数组的数字键。如果你有一个关联数组,它的键会被替换成0, 1, 2…
rsort()
:与
sort()
类似,不过是降序排列,同样会重置数字键。示例:
$numbers = [3, 1, 4, 1, 5, 9, 2];sort($numbers);print_r($numbers);// 输出:Array ( [0] => 1 [1] => 1 [2] => 2 [3] => 3 [4] => 4 [5] => 5 [6] => 9 )
我个人觉得,如果你只是想把一堆数值排整齐,不关心它们原来的索引,这两个函数简直是首选,简单粗暴有效。
立即学习“PHP免费学习笔记(深入)”;
asort()
和
arsort()
:保留键值关联的排序
asort()
:按数组的值进行升序排列,但它最棒的地方在于会保留键和值之间的关联。
arsort()
:按数组的值进行降序排列,同样保留键值关联。示例:
$fruits = ["d" => "lemon", "a" => "orange", "b" => "banana", "c" => "apple"];asort($fruits);print_r($fruits);// 输出:Array ( [c] => apple [b] => banana [d] => lemon [a] => orange )
这个在处理关联数组时特别有用,你可能需要根据商品价格排序,但又不想丢失商品ID和名称的对应关系,这时候
asort()
就是你的救星。
ksort()
和
krsort()
:按键排序
ksort()
:按数组的键进行升序排列。
krsort()
:按数组的键进行降序排列。示例:
$data = ["id_3" => "Alice", "id_1" => "Bob", "id_2" => "Charlie"];ksort($data);print_r($data);// 输出:Array ( [id_1] => Bob [id_2] => Charlie [id_3] => Alice )
有时候,数据的组织方式就是以键为核心的,比如配置项或者用户ID,这时候按键排序就显得非常自然了。
usort()
、
uasort()
、
uksort()
:自定义排序规则
这组函数强大之处在于它们接受一个回调函数,让你完全掌控排序逻辑。
usort()
:按值排序,但会重置数字键。
uasort()
:按值排序,并保留键值关联。
uksort()
:按键排序,并保留键值关联。回调函数需要接收两个参数,并根据比较结果返回 -1, 0, 或 1。示例:
$users = [ ["name" => "Alice", "age" => 30], ["name" => "Bob", "age" => 25], ["name" => "Charlie", "age" => 35],];usort($users, function($a, $b) { return $a['age'] $b['age']; // PHP 7+ 飞船操作符,简洁!});print_r($users);/*输出:Array ( [0] => Array ( [name] => Bob [age] => 25 ) [1] => Array ( [name] => Alice [age] => 30 ) [2] => Array ( [name] => Charlie [age] => 35 ))*/
这玩意儿简直是排序界的瑞士军刀,只要你能写出比较逻辑,就没有它排不了的。
PHP数组排序时如何保留键值关联?
这确实是新手常遇到的一个坑。当你用
sort()
或
rsort()
处理关联数组时,虽然值排好了,但原来的键都被0, 1, 2…这样的数字键给替换掉了,这往往不是我们想要的。这种行为被称为“重置键”,在某些场景下有用,但在另一些场景下则会
以上就是php如何对数组进行排序?php数组排序函数应用详解的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1273617.html
微信扫一扫
支付宝扫一扫