array_multisort()和array_column()联用效果直接叠满,1+1>100
先来看下两个函数的介绍和用法
array_column():
一般模式,不需要其中字段作为id,只需要提取val值
5698, 'first_name' => 'Peter', 'last_name' => 'Griffin', ], [ 'id' => 4767, 'first_name' => 'Ben', 'last_name' => 'Smith', ], [ 'id' => 3809, 'first_name' => 'Joe', 'last_name' => 'Doe', ], ];$last_names = array_column($a, 'last_name');print_r($last_names);//最简单模式?>
升级模式,需要其中字段作为id,另一字段作为val值
5698, 'first_name' => 'Peter', 'last_name' => 'Griffin', ], [ 'id' => 4767, 'first_name' => 'Ben', 'last_name' => 'Smith', ], [ 'id' => 3809, 'first_name' => 'Joe', 'last_name' => 'Doe', ], ];$last_names = array_column($a, 'last_name' ,'id');print_r($last_names);//id作为key,last_name作为val
array_multisort():
返回一个升序排列的数组:
当两个值相同时如何排序:
使用排序参数:
合并两个数组,并按数字降序排列:
以上是对两个函数的介绍和使用方法举例
下面开始合体进化,直接直呼我滴个*:
首先扩展下array_multisort(),如果对多个数组进行排序,排序结果是所有的数组都按第一个数组的顺序进行排列
');print_r($a2);print_r('
');print_r($a3);print_r('
');?>
然后开始合体:
将多维数组按照某一列的字段来进行排序
67, 'id' => 2);$data[] = array('volume' => 86, 'id' => 1);$data[] = array('volume' => 86, 'id' => 3);$data[] = array('volume' => 85, 'id' => 6);$data[] = array('volume' => 98, 'id' => 2);$data[] = array('volume' => 86, 'id' => 6);$data[] = array('volume' => 67, 'id' => 7);array_multisort(array_column($data, 'volume'), SORT_DESC,$data);//按volume倒序排?>
按volume倒序排,volume相同时,按id正序排
67, 'id' => 2);$data[] = array('volume' => 86, 'id' => 1);$data[] = array('volume' => 86, 'id' => 3);$data[] = array('volume' => 85, 'id' => 6);$data[] = array('volume' => 98, 'id' => 2);$data[] = array('volume' => 86, 'id' => 6);$data[] = array('volume' => 67, 'id' => 7);array_multisort(array_column($data,'volume'), SORT_DESC, array_column($data,'id'), SORT_ASC, $data);//按volume倒序排,volume相同时,按id正序排?>
按照年龄从大到小的顺序排列,如果年龄相同就按照名字升序排序
20, "name" => "a"], ["age" => 21, "name" => "d"], ["age" => 22, "name" => "e"], ["age" => 20, "name" => "b"], ["age" => 25, "name" => "c"] ]; array_multisort(array_column($array,'age'),SORT_NUMERIC,SORT_DESC,array_column($array,'name'),SORT_STRING,SORT_ASC,$array);print_r($array);?>
到此撒花.
来源地址:https://blog.csdn.net/qq_42154707/article/details/132490548