首页 > 语言 > PHP > 正文

PHP实现二维数组按某列进行排序的方法

2024-05-04 23:52:36
字体:
来源:转载
供稿:网友

本文实例讲述了PHP实现二维数组按某列进行排序的方法。分享给大家供大家参考,具体如下:

/** 二维数组 按某列排序* array_multisort($arr1,$arr2)* 手册 例子如下**/$data[] = array('volume' => 67, 'edition' => 2);$data[] = array('volume' => 86, 'edition' => 1);$data[] = array('volume' => 85, 'edition' => 6);$data[] = array('volume' => 98, 'edition' => 2);$data[] = array('volume' => 86, 'edition' => 6);$data[] = array('volume' => 67, 'edition' => 7);// 取得列的列表foreach ($data as $key => $row) {  $volume[$key] = $row['volume'];  $edition[$key] = $row['edition'];}// 将数据根据 volume 降序排列,根据 edition 升序排列// 把 $data 作为最后一个参数,以通用键排序array_multisort($volume, SORT_DESC, $edition, SORT_ASC, $data);/*************************************//* 从上面的例子不难看出,array_multisort()函数* 是将每一个二维数组的列作为 一个参数进行排序* 来达到整个数组的排序*//*************************************/function sigcol_arrsort($data,$col,$type=SORT_DESC){  if(is_array($data)){    $i=0;    foreach($data as $k=>$v){      if(key_exists($col,$v)){        $arr[$i] = $v[$col];        $i++;      }else{        continue;      }    }  }else{    return false;  }  array_multisort($arr,$type,$data);  return $data;}print_r(sigcol_arrsort($data,'edition',SORT_DESC));/*说白了 原理就是:新数组  原二维数组 2    array('volume' => 67, 'edition' => 2); 1    array('volume' => 86, 'edition' => 1); 6    array('volume' => 85, 'edition' => 6); 2    array('volume' => 98, 'edition' => 2); 6    array('volume' => 86, 'edition' => 6); 7    array('volume' => 67, 'edition' => 7);这两个数组的每一行都锁在一起,新数组一旦变动顺序,那么就会连带每一行的二维数组也跟着变换顺序 ,即新数组为参照物相当于查询子句中的 order by*/

运行结果:

Array(  [0] => Array    (      [volume] => 67      [edition] => 7    )  [1] => Array    (      [volume] => 85      [edition] => 6    )  [2] => Array    (      [volume] => 86      [edition] => 6    )  [3] => Array    (      [volume] => 67      [edition] => 2    )  [4] => Array    (      [volume] => 98      [edition] => 2    )  [5] => Array    (      [volume] => 86      [edition] => 1    ))

希望本文所述对大家PHP程序设计有所帮助。


注:相关教程知识阅读请移步到PHP教程频道。
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

图片精选