设为首页 收藏本站
查看: 1215|回复: 0

[经验分享] PHP数组排序函数合集

[复制链接]
累计签到:2 天
连续签到:1 天
发表于 2015-8-23 05:48:10 | 显示全部楼层 |阅读模式
  下边提到的几个数组函数的排序有一些共性:
1 数组被作为排序函数的参数,排序以后,数组本身就发生了改变,函数的返回值为bool类型。
2 函数
中出现a表示association,含义为,在按值排序的过程中,保持key=>value的对应关系不变
3 函数
中出现k表示key,含义为,在按值排序的过程中按照数组key而不是数组的值排序
4 函数中出现单r的表示reverse,含义为,按照跟不加r的相反的顺序排列
5 函数名中出现单u的表示user-defined含义为,使用用户自定义函数排序,如果函数的逻辑是参数1<参数2返回负数,则按照升序排列(p1小2返负升)。

--------------------sort函数升序排序--------------------------------

bool sort ( array &$array [, int $sort_flags= SORT_REGULAR ] )
<?php
$fruits = array("lemon", "orange", "banana", "apple");
sort($fruits);
var_dump($fruits);
?>
结果:
array

0 =>
  string

'apple' (length=5)
  1 =>
  string

'banana' (length=6)
  2 =>
  string

'lemon' (length=5)
  3 =>
  string

'orange' (length=6)
--------------------rsort降序排列--------------------
<?php
$fruits = array("lemon", "orange", "banana", "apple");
rsort($fruits);
var_dump($fruits);
?>
结果:
array
  0 =>
  string

'orange' (length=6)
  1 =>
  string

'lemon' (length=5)
  2 =>
  string

'banana' (length=6)
  3 =>
  string

'apple' (length=5)
---------------asort按照二维数组值的升序排列(保持key=>value的关联关系)-----------
<?php
$fruits = array("d" => "lemon", "a" => "orange", "b" => "banana", "c" => "apple");
asort($fruits);
var_dump($fruits);
?>
结果:
array
  'c' =>
  string

'apple' (length=5)
  'b' =>
  string

'banana' (length=6)
  'd' =>
  string

'lemon' (length=5)
  'a' =>
  string

'orange' (length=6)
--------------arsort按照二维数组值的降序排列(保持key=>value的关联关系)--------------
<?php
$fruits = array("d" => "lemon", "a" => "orange", "b" => "banana", "c" => "apple");
arsort($fruits);
var_dump($fruits);
?>
结果
array
  'a' =>
  string

'orange' (length=6)
  'd' =>
  string

'lemon' (length=5)
  'b' =>
  string

'banana' (length=6)
  'c' =>
  string

'apple' (length=5)
--------------------ksort按照数组的key升序排列-------------- <?php
  $fruits = array("d"=>"lemon", "a"=>"orange", "b"=>"banana", "c"=>"apple");
ksort($fruits);
var_dump($fruits);
?>
结果
array

'a' =>
  string

'orange' (length=6)
  'b' =>
  string

'banana' (length=6)
  'c' =>
  string

'apple' (length=5)
  'd' =>
  string

'lemon' (length=5)
---------------------krsort按照数组key的降序排列--------------------------------
<?php
$fruits = array("d"=>"lemon", "a"=>"orange", "b"=>"banana", "c"=>"apple");
krsort($fruits);
var_dump($fruits);
?>
array
  'd' =>
  string

'lemon' (length=5)
  'c' =>
  string

'apple' (length=5)
  'b' =>
  string

'banana' (length=6)
  'a' =>
  string

'orange' (length=6)

----------------usort函数按照用户自定义的函数排序----------------
<?php
function cmp($a, $b)
{
    if ($a == $b) {
        return 0;
    }
    return ($a < $b) ? -1 : 1;
}
$a = array(3, 2, 5, 6, 1);
usort($a, "cmp");
var_dump($a);
?>
结果:
array
  0 =>
  int

1
  1 =>
  int

2
  2 =>
  int

3
  3 =>
  int

5
  4 =>
  int

6
-----------------uksort使用自定义函数按照数组的key排序-----------------
<?php
function cmp($a, $b)
{
    $a = preg_replace('@^(a|an|the) @', '', $a);
    $b = preg_replace('@^(a|an|the) @', '', $b);
    return strcasecmp($a, $b);
}
$a = array("John" => 1, "the Earth" => 2, "an apple" => 3, "a banana" => 4);
uksort($a, "cmp");
var_dump($a);
?>
结果:
array
  'an apple' =>
  int

3
  'a banana' =>
  int

4
  'the Earth' =>
  int

2
  'John' =>
  int

1
-------------------uasort将数组用自定义函数按照value排序,保持索引关系不变---------
<?php
// Comparison function
function cmp($a, $b) {
    if ($a == $b) {
        return 0;
    }
    return ($a < $b) ? -1 : 1;
}
// Array to be sorted
$array = array('a' => 4, 'b' => 8, 'c' => -1, 'd' => -9, 'e' => 2, 'f' => 5, 'g' => 3, 'h' => -4);
var_dump($array);
// Sort and print the resulting array
uasort($array, 'cmp');
var_dump($array);
?>
结果:
array
  'a' =>
  int

4
  'b' =>
  int

8
  'c' =>
  int

-1
  'd' =>
  int

-9
  'e' =>
  int

2
  'f' =>
  int

5
  'g' =>
  int

3
  'h' =>
  int

-4
array
  'd' =>
  int

-9
  'h' =>
  int

-4
  'c' =>
  int

-1
  'e' =>
  int

2
  'g' =>
  int

3
  'a' =>
  int

4
  'f' =>
  int

5
  'b' =>
  int

8
-------------------array_multisort排序多个数组或多维数组---------
<?php
$ar = array(
       array("10", 11, 100, 100, "a"),
       array(   1,  2, "2",   3,   1)
      );
array_multisort($ar[0], SORT_ASC, SORT_STRING,
                $ar[1], SORT_NUMERIC, SORT_DESC);
var_dump($ar);
?>
结果:
array
  0 =>
    array
      0 =>
  string

'10' (length=2)
      1 =>
  int

100
      2 =>
  int

100
      3 =>
  int

11
      4 =>
  string

'a' (length=1)
  1 =>
    array
      0 =>
  int

1
      1 =>
  int

3
      2 =>
  string

'2' (length=1)
      3 =>
  int

2
      4 =>
  int

1
//说明:
1 上例中:$ar数组优先按照$ar[0]的字符串值升序排列,如果字符串值相等,再按照$ar[1]数组的数字值降序排列。
2 array_multisort函数的任意一个位置的参数如果是数组,表示排序时用的值,
如果有多个数组参数,优先按照前边的数组值进行排序,如果是常量,例如
SORT_ASC
, SORT_DESC, SORT_REGULAR,SORT_NUMERIC, SORT_STRING.
表示排序方法(数组取值前优先)。



==========================================================================================
PHP二维数组排序函数
  PHP一维数组的排序可以用sort(),asort(),arsort()等函数,但是PHP二维数组的排序需要自定义。
  以下函数是对一个给定的二维数组按照指定的键值进行排序,先看函数定义:






view sourceprint?



01.function array_sort($arr,$keys,$type='asc'){

02.$keysvalue = $new_array = array();

03.foreach ($arr as $k=>$v){

04.$keysvalue[$k] = $v[$keys];

05.}

06.if($type == 'asc'){

07.asort($keysvalue);

08.}else{

09.arsort($keysvalue);

10.}

11.reset($keysvalue);

12.foreach ($keysvalue as $k=>$v){

13.$new_array[$k] = $arr[$k];

14.}

15.return $new_array;

16.}   它可以对二维数组按照指定的键值进行排序,也可以指定升序或降序排序法(默认为升序),用法示例:






view sourceprint?



01.$array = array(

02.array('name'=>'手机','brand'=>'诺基亚','price'=>1050),

03.array('name'=>'笔记本电脑','brand'=>'lenovo','price'=>4300),

04.array('name'=>'剃须刀','brand'=>'飞利浦','price'=>3100),

05.array('name'=>'跑步机','brand'=>'三和松石','price'=>4900),

06.array('name'=>'手表','brand'=>'卡西欧','price'=>960),

07.array('name'=>'液晶电视','brand'=>'索尼','price'=>6299),

08.array('name'=>'激光打印机','brand'=>'惠普','price'=>1200)

09.);

10.

11.$ShoppingList = array_sort($array,'price');

12.print_r($ShoppingList);  上面是对$array这个二维数组按照'price'从低到高的排序。
  输出结果:(略)。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-102775-1-1.html 上篇帖子: 彻底理解PHP的SESSION机制 下篇帖子: NotePad++ for PHP
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表