PHP 二维数组根据某个字段排序

PHP 二维数组根据某个字段排序PHP 二维数组根据某个字段排序

大家好,又见面了,我是你们的朋友全栈君。

数据:
$data[] = array(‘customer_name’ => ‘小李’, ‘money’ => 12, ‘distance’ => 2, ‘address’ => ‘长安街C坊’);
$data[] = array(‘customer_name’ => ‘王晓’, ‘money’ => 30, ‘distance’ => 10, ‘address’ => ‘北大街30号’);
$data[] = array(‘customer_name’ => ‘赵小雅’, ‘money’ => 89, ‘distance’ => 6, ‘address’ => ‘解放路恒基大厦A座’);
$data[] = array(‘customer_name’ => ‘小月’, ‘money’ => 150, ‘distance’ => 5, ‘address’ => ‘天桥十字东400米’);
$data[] = array(‘customer_name’ => ‘李亮亮’, ‘money’ => 45, ‘distance’ => 26, ‘address’ => ‘天山西路198弄’);
$data[] = array(‘customer_name’ => ‘董娟’, ‘money’ => 67, ‘distance’ => 17, ‘address’ => ‘新大南路2号’);

方法一:

function arraySort($array,$keys,$sort='asc') { 
   
    $newArr = $valArr = array();
    foreach ($array as $key=>$value) { 
   
        $valArr[$key] = $value[$keys];
    }
    ($sort == 'asc') ?  asort($valArr) : arsort($valArr);
    reset($valArr);
    foreach($valArr as $key=>$value) { 
   
        $newArr[$key] = $array[$key];
    }
    return $newArr;
}

方法二:

/** * 二维数组根据某个字段排序 * @param array $array 要排序的数组 * @param string $keys 要排序的键字段 * @param string $sort 排序类型 SORT_ASC SORT_DESC * @return array 排序后的数组 */
function arraySort($array, $keys, $sort = SORT_DESC) { 
   
    $keysValue = [];
    foreach ($array as $k => $v) { 
   
        $keysValue[$k] = $v[$keys];
    }
    array_multisort($keysValue, $sort, $array);
    return $array;
}

# 按距离降序排序
$a = arraySort($data, 'distance', SORT_DESC);
print_r($a);
# 按money升序排序
$b = arraySort($data, 'money', SORT_ASC);
print_r($b);
Array
(
    [0] => Array
        (
            [customer_name] => 李亮亮
            [money] => 45
            [distance] => 26
            [address] => 天山西路198)

    [1] => Array
        (
            [customer_name] => 董娟
            [money] => 67
            [distance] => 17
            [address] => 新大南路2)

扩展:

定义和用法
reset() 函数将内部指针指向数组中的第一个元素,并输出。
current() – 返回数组中的当前元素的值。
end() – 将内部指针指向数组中的最后一个元素,并输出。
next() – 将内部指针指向数组中的下一个元素,并输出。
prev() – 将内部指针指向数组中的上一个元素,并输出。
each() – 返回当前元素的键名和键值,并将内部指针向前移动。

sort 对数组的值按照升序排列(rsort降序),不保留原始的键
ksort 对数组的键按照升序排列(krsort降序) 保留键值关系
asort 对数组的值按照升序排列(arsort降序),保留键值关系

array_multisort
  • 排序顺序标志:

    SORT_ASC – 按照上升顺序排序
    SORT_DESC – 按照下降顺序排序

  • 排序类型标志:

    SORT_REGULAR – 将项目按照通常方法比较
    SORT_NUMERIC – 将项目按照数值比较
    SORT_STRING – 将项目按照字符串比较
    每个数组之后不能指定两个同类的排序标志。每个数组后指定的排序标志仅对该数组有效 – 在此之前为默认值 SORT_ASC 和 SORT_REGULAR。

$ar = array(
    array("b10", 'c11', 101, 100, "a"),
    array(1, 2, "2", 9, 5)
);
array_multisort($ar[0], SORT_ASC, SORT_STRING, $ar[1], SORT_NUMERIC, SORT_DESC);
print_r($ar);
Array
(
    [0] => Array
        (
            [0] => 100
            [1] => 101
            [2] => a
            [3] => b10
            [4] => c11
        )

    [1] => Array
        (
            [0] => 9
            [1] => 2
            [2] => 5
            [3] => 1
            [4] => 2
        )

)
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/105808.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • openssl生成cer证书_tls证书生成

    openssl生成cer证书_tls证书生成一安装opensslwgethttp://www.openssl.org/source/openssl-1.0.0a.tar.gztarzxvfopenssl-1.0.0a.tar.gzcdopenssl-1.0.0a./config–prefix=/usr/local/opensslmake&&makeinstall二创建主证书先创建一个ssl的目录:m…

    2022年9月19日
    2
  • FEC原理及其实现[通俗易懂]

    FEC原理及其实现[通俗易懂]感谢原作者:http://blog.csdn.net/rootusers/article/details/49097257视频会议中通常使用的FEC/QOS技术,这方面的资料比较复杂和稀少,根据这么多年的工作经验,做一下分享。 在IP视频通话中丢包造成的影响多种多样。其中对视频质量的影响主要有:马赛克现象、局部变形(图像的某些区域不清晰)、图像模糊、屏幕频繁刷新或闪

    2022年8月11日
    9
  • 第一个Java项目———Java实现简单图书管理系统(GUI)

    第一个Java项目———Java实现简单图书管理系统(GUI)暑假写了个图书管理系统,编译器用的是eclipse,加入了WindowBuilder插件做界面(做的特丑),数据库用的是MySQL。实现了图书的查询,借阅,归还,删除,增加。用户的删除,查询。分为管理员和用户。一,程序整体框架从项目开始,无从下手,随着学习的深入,慢慢的熟悉了开发流程,先把整体框架搭起来,这个过程可以减少后续的一些麻烦,做数据库前先想好需求,…

    2022年7月15日
    12
  • Java进阶:java开源商城系统源码

    Java进阶:java开源商城系统源码正文ZooKeeper很流行,有个基本的疑问:ZooKeeper是用来做什么的?之前没有ZK,为什么会诞生ZK?OK,解答一下上面的疑问:(下面是凭直觉说的)ZooKeeper是用于简化分布式应用开发的,对开发者屏蔽一些分布式应用开发过程中的底层细节ZooKeeper对外暴露简单的API,用于支持分布式应用开发ZooKeeper在提供上述功能的同时,其还是一个高性能、高可用、高可靠的分布式集群上面说这么多,总结一下,ZK能解决分布式应用开发的问题,ZK能很好的解决

    2022年7月8日
    20
  • Implementing the Singleton Pattern in C#

    Implementing the Singleton Pattern in C#

    2021年9月2日
    48
  • Java高级程序员面试经历

    Java高级程序员面试经历05 年毕业 到现在已经快 12 年了 如果一直在技术上辛勤耕耘 足够的努力 加上多年的技术经验累积 这个年纪混到架构师级 技术总监甚至 CTO 还是有可能的 不过因为我自己的经历有点特别 2011 年初离开深圳 之后就很少接触编程了 所以水平基本上停留在那个年代 自己不仅没有达到这个级别 甚至去面试的时候 还要和九零后一起竞争 实际上很难遇到比我年纪更大的面试者了 重新回到深圳 见下老同学 有和别人一起开公

    2025年8月4日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号