PHP将二位数组按照第二维的某个元素的值进行排序

例如:

 1 //原始数组是这样的,希望能够按照第二维中的run_date升序或者降序进行排序:
 2 $arr=array(
 3                 0=>array(
 4                     ‘run_date‘=>‘2017-11-21‘,
 5                     ‘count‘=>‘5‘
 6                 ),
 7                 1=>array(
 8                     ‘run_date‘=>‘2017-11-20‘,
 9                     ‘count‘=>‘10‘
10                 ),
11                 2=>array(
12                     ‘run_date‘=>‘2017-11-22‘,
13                     ‘count‘=>‘10‘
14                 )
15             );
16 //希望得到:
17 $arr=array(
18                 0=>array(
19                     ‘run_date‘=>‘2017-11-20‘,
20                     ‘count‘=>‘5‘
21                 ),
22                 1=>array(
23                     ‘run_date‘=>‘2017-11-21‘,
24                     ‘count‘=>‘10‘
25                 ),
26                 2=>array(
27                     ‘run_date‘=>‘2017-11-22‘,
28                     ‘count‘=>‘10‘
29                 )
30 );

当然,用循环遍历是可以解决的,但是还是觉得效率有点低,这里有另外一个解决方案,是使用两个PHP提供的函数:

array_column array_multisort

还是上面的数组:
//先用array_column 多维数组按照纵向(列)取出

$date = array_column($arr, ‘run_date‘);

//上面得到的结果:array(0=>‘2017-11-21‘,1=>‘2017-11-20‘,3=>‘2017-11-22‘)

//再用array_multisort  结合array_column得到的结果对$arr进行排序

array_multisort($date,SORT_ASC,$arr);

//最终的结果:
$arr=array(
                0=>array(
                    ‘run_date‘=>‘2017-11-20‘,
                    ‘count‘=>‘5‘
                ),
                1=>array(
                    ‘run_date‘=>‘2017-11-21‘,
                    ‘count‘=>‘10‘
                ),
                2=>array(
                    ‘run_date‘=>‘2017-11-22‘,
                    ‘count‘=>‘10‘
                )
            );

附:

1、array_column 参考我之前的博客 http://www.cnblogs.com/Steven-shi/p/5897745.html

2、array_multisort array_multisort() 函数对多个数组或多维数组进行排序,可以用来一次对多个PHP二维数组排序进行排序,或者根据某一维或多维对多维数组进行排序

参数中的数组被当成一个表的列并以行来进行排序 - 这类似 SQL 的 ORDER BY 子句的功能。第一个数组是要排序的主要数组。数组中的行(值)比较为相同的话,就会按照下一个输入数组中相应值的大小进行排序,依此类推。

第一个参数是数组,随后的每一个参数可能是数组,也可能是下面的排序顺序标志(排序标志用于更改默认的排列顺序)之一:

SORT_ASC - 默认,按升序排列。(A-Z)
SORT_DESC - 按降序排列。(Z-A)
随后可以指定排序的类型:

SORT_REGULAR - 默认。将每一项按常规顺序排列。
SORT_NUMERIC - 将每一项按数字顺序排列。
SORT_STRING - 将每一项按字母顺序排列。
array_multisort(array1,sorting order,sorting type,array2,array3...)
array1 : 必需。规定输入的数组。

sorting order : 可选。规定排列顺序。可能的值是 SORT_ASC 和 SORT_DESC。

sorting type : 可选。规定排序类型。可能的值是SORT_REGULAR、SORT_NUMERIC和SORT_STRING。

array2 : 可选。规定输入的数组。

array3 : 可选。规定输入的数组。

注释:字符串键名将被保留,但是数字键将被重新索引,从 0 开始,并以 1 递增。

注释:您可以在每个数组后设置排序顺序和排序类型。如果没有设置,每个数组参数会使用默认值。

PHP二维数组排序是按照第一个数组进行排序,并且调整后面的顺序。像这样的数组:

array( ‘id‘ => array(1,3,2), ‘data‘=>array(‘a‘,‘c‘,‘b‘))

只要按照id进行多维排序,就可以了。但是很多时候,我们构造出的数组是这样的:

array( array(‘id‘=>1,‘data‘=>‘a‘), array(‘id‘=>3,‘data‘=>‘c‘), array(‘id‘=>2,‘data‘=>‘b‘) );

PHP二维数组排序的元素是按行排列的,需要按其中的一列进行排序。PHP好像也没提供类似矩阵转置的函数,所以不能直接使用array_multisort进行多维排序。不过只需要先把排序的列抽取出来,作为第一个参数传给array_multisort即可

时间: 2024-10-14 12:34:36

PHP将二位数组按照第二维的某个元素的值进行排序的相关文章

二位数组按某一个或多个字段值(升序/降序)排序

输出结果:

《Javascript权威指南》学习笔记之十二:数组、多维数组和符合数组(哈希映射)

Array(数组)是JavaScript中较为复杂的数据类型,同Java.C#.VB等程序语言的数组相比,Javascript数组中的元素不必为相同的数据类型,可以在数组每个元素上混合使用数字.日期.字符串.Object,甚至添加一个嵌套数组. 一.创建数组 1.var arr1 = new Array(); /var  arr2 = new Array(length); /var arr3 = new Array(element1,element2...); var arr4 = [eleme

C++ 出现bug :二位数组的操作运算,求非对角线的元素的和

编写一个通用程序,求出二位数组(行数和列数必须相等)的非对角线的元素之和,试建立类MATRIX完成上述功能 #include<iostream> using namespace std; class MATRIX { public: void mATRIX(); void MATRIX_sum(); void MATRIX_display(); static int fact_len;//定义静态变量 private: int sum; int a[40][40]; }; int MATRIX

在控制台输入字母然后在控制台打印相应的二位数组字母,要求一行打印

1 package MyHomeWork; 2 3 import java.util.HashMap; 4 import java.util.Map; 5 import java.util.Scanner; 6 7 /** 8 * Created by zhouyubin on 7/11/14. 9 */ 10 public class Test2 { 11 private static final char[][] print_a={{' ',' ',' ','A',' ',' ',' ','

二位数组环状最大子矩阵

由于上次二位数组,使用了函数,所以这次只要修改函数就可以了. //Powered by lzr! #include<iostream> using namespace std; int yiwei_max(int n,int a[]) { int temp=0,sum=-999999999; int j=0,k=0,i; for(i=0;i<n;i++) { if(temp>0) { temp+=a[i]; } else { temp=a[i]; if(a[i]>0 &

二位数组中的查找——杨氏矩阵

------------------------------------------------------------------------------------------------- "杨氏矩阵":即数组元素从左向右依次递增,从上到下依次递增.要想在该数组中查找数,首 先该数组得满足"杨氏矩阵"的特点.为了方便理解我们可以将一个二位数组看作是一个矩阵,假设i 为行,j为列,数组为str,那么只要满足(str[i][j]<str[i][j+1] &a

二位数组传参及二位数组动态分配问题

//二位数组参数传递 //1. void display1(int arr[][4], const int rows) { for (int i = 0; i < rows; i++) { for (int j = 0; j < 4; j++) { cout << arr[i][j] << ' '; } cout << endl; } cout << endl; } //2. void display2(int(*parr)[4], const

2019.12.10 二位数组

定义格式 * a 第一种定义格式: * int[][] arr = new int[3][4];// arr里面包含3个数组 每个数组里面有四个元素 * 上面的代码相当于定义了一个3*4的二维数组,即二维数组的长度为3,二维数组中的每个元素又是一个长度为4的数组 * b 第二种定义格式 * int[][] arr = new int[3][]; * 第二种方式和第一种类似,只是数组中每个元素的长度不确定 * c 第三种定义格式 * int[][] arr = {{1,2},{3,4,5,6},{

c语言二位数组与指针

问题,以下输出的结果是什么,区别在于哪? void main() { int a[3][4] = { 1,2,3,4,5,6,7,8,9,10,11,12 }; //输出的3个地址都一样,差别在哪? printf("\n%x",a); printf("\n%x",*a); printf("\n%x",&a); system("pause"); } 像我这种野生码农看到这个问题基本懵了,好吧我们先通过一维数组来理解. v