php二维数组排序问题怎么解决
本篇内容主要讲解“php二维数组排序问题怎么解决”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“php二维数组排序问题怎么解决”吧!
php二维数组排序
测试数据
$arr = [
'a' => ['a' => 11, 'b' => 12, 'c' => 13],
'b' => ['a' => 10, 'b' => 13, 'c' => 12],
'c' => ['a' => 12, 'b' => 11, 'c' => 10],
];
通过usort排序
# usort 排序会导致二维数组的key改变(key a,b,c 变成 0,1,2 这种)
# 如果不在意key的改变可以用这种
# $arr 是引用
usort($arr, function ($current, $next) {
# 正序排
return $current['a'] > $next['a'];
});
通过array_multisort排序
$arr = [
'a' => ['a' => 11, 'b' => 12, 'c' => 13],
'b' => ['a' => 10, 'b' => 13, 'c' => 12],
'c' => ['a' => 12, 'b' => 11, 'c' => 10],
];
# 以二维数组的a作为比较值
$key = array_column(array_values($arr), 'a');
# 第一个参数需要提供二维数组排序依据
# 第二个排序方式 SORT_ASC:正序 SORT_DESC:倒序
# 第三个参数 要排序的二维数组,改动直接操作在该数组上
# 排序能保证key不改变
array_multisort($key, SORT_ASC, $arr);
php二维数组排序算法函数
<?php
// 二维数组排序算法函数,能够具有通用性,可以调用php内置函数。
function array_sort(&$arr, $order = []){
$result = [];
if (empty($arr)) {
return $result;
}
uasort($arr, function ($a, $b) use ($order) {
foreach ($order as $key => $sort) {
array_shift($order);
if ($a[$key] == $b[$key]) {
continue;
}
if ($sort === 'DESC') {
return ($a[$key] > $b[$key]) ? -1 : 1;
} else {
return ($a[$key] > $b[$key]) ? 1 : -1;
}
}
return 0;
});
foreach ($arr as $value) {
$result[] = $value;
}
return $arr = $result;
}
// 测试
$ps = array(
array('id' => 1, 'name' => 'zhangcan', 'age' => 13),
array('id' => 2, 'name' => 'lisi', 'age' => 16),
array('id' => 3, 'name' => 'wangwu', 'age' => 17),
array('id' => 4, 'name' => 'wangwu', 'age' => 18),
);
// $ret = array_sort($person, ['name' => 'ASC']);
$ret = array_sort($ps, ['name'=>'ASC', 'age'=>'DESC']);
print_r($ret);
相关内容
这些是最新的
热门排行
- THINKPHP5+GatewayWorker+Workerman 开发在线客服系统
- 在手机浏览器网页中点击链接跳转到微信界面的方法
- 尊云网站目录系统 ThinkPHP5网站分类目录程序 v2.2.221011
- CentOS 7安装shadowsock(一键安装脚本)
- AdminTemplate 基于LayUI 2.4.5实现的网站后台管理模板
- 用NW.js(node-webkit)开发多平台的桌面客户端
- PHP生成随机昵称/用户名
- THINKPHP5网站分类目录程序 尊云网站目录系统
- 织梦(DEDECMS)微信支付接口 微信插件
- 基于LayUI开发的 网站后台管理模板 BeginnerAdmin
- 响应式后台网站模板 - AMA.ADMIN
- layuiAdmin后台管理模板 Iframe版
- LayUI 1.0.9 升级 至 LayUI 2.1.4 方法
- 简洁清爽的会员中心模板
- jQuery幸运大转盘抽奖活动代码