zoukankan      html  css  js  c++  java
  • php二维数组排序方法(array_multisort,usort)

    一维数组排序可以使用asort、ksort等一些方法进程排序,相对来说比较简单。二维数组的排序怎么实现呢?使用array_multisort和usort可以实现

    例如像下面的数组:

    $users = array(
        array('name' => 'tom', 'age' => 20)
        , array('name' => 'anny', 'age' => 18)
        , array('name' => 'jack', 'age' => 22)
    )

    希望能按照age从小到大进行排序。有两个方法:

     

    1、使用array_multisort

    使用这个方法,会比较麻烦些,要将age提取出来存储到一维数组里,然后按照age升序排列。具体代码如下:

     

    1 $ages = array();
    2 foreach ($users as $user) {
    3     $ages[] = $user['age'];
    4 }
    5 
    6 array_multisort($ages, SORT_ASC, $users);

    执行后,$users就是排序好的数组了,可以打印出来看看。如果需要先按年龄升序排列,再按照名称升序排列,方法同上,就是多提取一个名称数组出来,最后的排序方法这样调用:

    array_multisort($ages, SORT_ASC, $names, SORT_ASC, $users);

     

    2、使用usort

    使用这个方法最大的好处就是可以自定义一些比较复杂的排序方法。例如按照名称的长度降序排列:

    1 usort($users, function($a, $b) {
    2             $al = strlen($a['name']);
    3             $bl = strlen($b['name']);
    4             if ($al == $bl)
    5                 return 0;
    6             return ($al > $bl) ? -1 : 1;
    7 });

    这里使用了匿名函数,如果有需要也可以单独提取出来。其中$a, $b可以理解为$users数组下的元素,可以直接索引name值,并计算长度,而后比较长度就可以了。

  • 相关阅读:
    paraview将csv格式显示为云图
    Valgrind安装与使用
    vscode+WSL+Debug+Cmake+OpenGL
    MFiX中DEM颗粒信息随时间变化
    origin添加两个Y轴
    conda回滚
    onedrive同步其他任意文件夹
    MFiX-DEM中的并行碰撞搜索
    MFiX-DEM中的串行碰撞搜索
    【Go】四舍五入在go语言中为何如此困难
  • 原文地址:https://www.cnblogs.com/redfire/p/7695724.html
Copyright © 2011-2022 走看看