php usort 使用用户自定义的比较函数对二维数组中的值进行排序
作者:mdxy-dxy 发布时间:2023-11-21 23:08:28
标签:排序,php,usort
今天发现一个很好用二维数组排序的php方法,usort,推荐给大家,以后二维数组里面,要按照一个字段的值排序用这个方法简单高效,例如下面的数组:
[guess_subject] => Array
(
[0] => Array
(
[subject_id] => 4587
[game_id] => 9228
[parent_category_id] => 78
[subject_title] => 全场比赛两队总得分之和是
[subject_date_time] => 1490668200
[status] => 2
[subject_answer] => 0
[totle_join] => 0
[max_nickname] =>
[max_currency] =>
)
[1] => Array
(
[subject_id] => 4588
[game_id] => 9228
[parent_category_id] => 78
[subject_title] => 本场比赛是否有加时赛
[subject_date_time] => 1490668200
[status] => 2
[subject_answer] => 0
[totle_join] => 0
[max_nickname] =>
[max_currency] =>
)
[2] => Array
(
[subject_id] => 4584
[game_id] => 9228
[parent_category_id] => 78
[subject_title] => 第二节两队总得分之和是
[subject_date_time] => 1490668200
[status] => 1
[subject_answer] => 0
[totle_join] => 0
[max_nickname] =>
[max_currency] =>
)
[3] => Array
(
[subject_id] => 4585
[game_id] => 9228
[parent_category_id] => 78
[subject_title] => 第三节两队总得分之和是
[subject_date_time] => 1490668200
[status] => 2
[subject_answer] => 0
[totle_join] => 0
[max_nickname] =>
[max_currency] =>
)
)
要按照status字段的升序排列的话,只需要这样写
foreach($data as $key => &$value) {
// 按照status的升序排序,使用用户自定义的比较函数对数组中的值进行排序,
// 本函数将用用户自定义的比较函数对一个数组中的值进行排序。 如果要排序的数组需要用一种不寻常的标准进行排序,那么应该使用此函数。
// 在第一个参数小于,等于或大于第二个参数时,该比较函数必须相应地返回一个小于,等于或大于 0 的整数。
usort($value['guess_subject'], function($a, $b){
if ($a['status'] == $b['status'])
return 0;
return ($a['status'] < $b['status']) ? -1 : 1;
});
}
return $data;
就会按照status的 升序排列啦, status=1 的数组单元会排在前面


猜你喜欢
- 前言在开始本文之前,首先要知道Python中对象包含的三个基本要素,分别是:id(身份标识)、python type()(数据类型)和val
- SQL Server 2000 清理日志精品教程SQL Server 2000 数据库日志太大!如何清理SQL Server 2000的日志
- 变量的缓存机制变量的缓存机制(以下内容仅对python3.6.x版本负责)机制只要有两个值相同,就只开辟一个空间为什么要有这样的机制在计算机
- 在命令行中运行python代码是很常见的,下面介绍如何定义命令后面跟的参数。1 常规用法Python代码中主要使用下面
- 闭包(closure)不是什么可怕的东西。如果用对了地方,它们其实可以很强大。闭包就是由其他函数动态生成并返回的函数,通俗地讲,在一个函数的
- 一直都在网上抄别人写的电话,邮箱正则表达式,今天稍微有点闲情,把一直想自己写个这样的表达式的心愿给完成:/** * 邮箱地址正则表
- 我不知道有多少人在使用浏览器的书签,这东东有时候实在是很有用的,比如现在说到的jQuerify书签。jQuerify书签的功能很简单,那就是
- 前言一般从数据库或者是从日志文件读出的数据均带有时间序列,做时序数据处理或者实时分析都需要对其时间序列进行归类归档。而Pandas是处理这些
- 本文详细讲述了MYSQL日志的正确删除方法。分享给大家供大家参考,具体如下:1.查找:MySQL> show binary logs;
- 1. 首先确认python的版本为2.3.4以上,如果不是需要升级python的版本 python -V
- JSP 开发之 releaseSession的实例详解Hibernate可以实现分页查询,昨天试了一下,分页效果不错。但是发现了一个问题,就
- 1、安装pip install mediapipe2、代码实现# -*- coding: utf-8 -*-""&quo
- 首先创建scrapy项目命令:scrapy startproject douban_read创建spider命令:scrapy genspi
- bug1无法正常使用cmd或pycharm正常安装,报错截图如下:解决(1): 这种情况下,我们就不能使用cmd或pycharm进
- 这篇文章主要介绍了python标识符命名规范原理解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友
- 误区 #21:数据库损坏可以通过重启SQL Server或是Windows,或是附加和分离数据库解决 错误 SQL Server中没有任何一
- 按照本地时间的javascript date.getDate()方法返回月份的一天,在指定日期。由getDate返回的值是1到3
- 如下所示:#!/usr/bin/python#coding:utf-8import MySQLdbimport time,datetime#
- oracle排序后如何获取第一条数据场景想要获取下列sql的数据的第一条select NEXT_FOLLOWUP_DATE fr
- django静态文件配置原理静态文件配置就是为了让用户请求时django服务器能找到静态文件返回。首先要理解几个概念:媒体文件:用户上传的文