-
PHP关联数组排序几种方法
对于普通数据排序我们直接使用系统自带数组排序函数即可,如果是关系数组排序你知道如何操作吧?下面来给各位整理了几个例子大家一起来看看吧.
参数说明:$data 目标数组 $key 排序字段, $sort 排序规则,代码如下:
- function getSortArray($data,$key,$sort='ASC')
- {
- if(!is_array($data))
- {
- return false;
- }
- $len = count($data);
- for($k=1; $k<$len; $k++)
- {
- for($j=$len-1,$i=0;$i<$len-$k;$i++,$j--)
- {
- if(strtoupper($sort) == 'DESC')
- {
- $flag = $data[$j][$key]>$data[$j-1][$key];
- }
- else
- {
- $flag = $data[$j][$key]<$data[$j-1][$key];
- }
- if($flag)
- {
- $tmp = $data[$j];
- $data[$j] = $data[$j-1];
- $data[$j-1] = $tmp;
- } //开源软件:phpfensi.com
- }
- }
- return $data;
- }
- //使用方法:
- $a = array(
- array('name'=>'stone','age'=>17,'sex'=>'男'),
- array('name'=>'sunny','age'=>28),
- array('name'=>'grass','age'=>16,'sex'=>'女'),
- array('name'=>'sea','age'=>15,'birthday'=>'1987-08-16')
- );
- print_r(getSortArray($a,'age','desc'));
- //结果:
- Array
- (
- [0] => Array
- (
- [name] => sunny
- [age] => 28
- )
- [1] => Array
- (
- [name] => stone
- [age] => 17
- [sex] => 男
- )
- [2] => Array
- (
- [name] => grass
- [age] => 16
- [sex] => 女
- )
- [3] => Array
- (
- [name] => sea
- [age] => 15
- [birthday] => 1987-08-16
- )
- )
不知道你有没有看懂呢?没懂我们再看两个数组排序例子,要对数组针对age字段进行排序,php自带的简单sort功能函数,显然都不能满足需求,因此需要自己写一个快速排序代码来实现相应的需求,代码如下:
- <?php
- /**
- * Description:获取中枢点的位置
- *
- * @param array $array
- * @param int $left
- * @param int $right
- * @param string $field
- * @return int
- */
- function fetchArrayPivot (&$array, $left, $right, $field)
- {
- // 基准定义
- $stand = $array[$left];
- // 遍历数组
- while ($left < $right) {
- while ($left < $right && $array[$right][$field] >= $stand[$field]) {
- $right --;
- }
- if ($left < $right) {
- $array[$left ++] = $array[$right];
- }
- while ($left < $right && $array[$left][$field] <= $stand[$field]) {
- $left ++;
- }
- if ($left < $right) {
- $array[$right --] = $array[$left];
- }
- }
- // 获取中枢点位置
- $array[$left] = $stand;
- return $left;
- }
- /**
- * Description:快速排序主程序
- *
- * @param array $array
- * @param int $begin
- * @param int $end
- * @param string $field
- */
- function quickSort (&$array, $begin, $end, $field)
- {
- // 变量定义
- $pivot = null;
- if ($begin < $end) {
- $pivot = fetchArrayPivot($array, $begin, $end, $field);
- quickSort($array, $begin, $pivot - 1, $field);
- quickSort($array, $pivot + 1, $end, $field);
- }
- }
- ?>
调用示例:
- <?php
- $array = array(
- array(
- 'name' => "xiao",
- 'age' => 3
- ),
- array(
- 'name' => 'wang',
- 'age' => 1
- ),
- array(
- 'name' => 'chen',
- 'age' => 2
- ),
- array(
- 'name' => 'zhengyi',
- 'age' => 4
- ),
- array(
- 'name' => 'chai',
- 'age' => 14
- )
- );
- $begin = getTime();
- quickSort($array, 0, count($array) - 1, 'age');
- print_r($array);
- $end = getTime();
- $spend = $end - $begin;
- //开源软件:phpfensi.com
- echo "花费时间为:".$spend."秒n";
- function getTime()
- {
- list($msec, $sec) = explode(" ", microtime());
- return (float)$msec + (float)$sec;
- }
- ?>
出处:http://www.phpfensi.com/php/20150411/9206.html
栏目列表
最新更新
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
Python初学者友好丨详解参数传递类型
如何有效管理爬虫流量?
SQL SERVER中递归
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
这是目前我见过最好的跨域解决方案!
减少回流与重绘
减少回流与重绘
如何使用KrpanoToolJS在浏览器切图
performance.now() 与 Date.now() 对比
一款纯 JS 实现的轻量化图片编辑器
关于开发 VS Code 插件遇到的 workbench.scm.
前端设计模式——观察者模式
前端设计模式——中介者模式
创建型-原型模式