PHP数据根据多个条件排序,PHP多维数组指定多字段排序的示例代码

介绍array_multisort方法

array_multisort — 对多个数组或多维数组进行排序.其php 手册中的说明如下:

bool array_multisort ( array &$arr [, mixed $arg = SORT_ASC [, mixed $arg = SORT_REGULAR [, mixed $... ]]] )

参数

arr

要排序的一个 array。

arg

接下来的每个参数可以是另一个 array 或者是为之前 array 排序标志选项参数: SORT_ASC, SORT_DESC,SORT_REGULAR, SORT_NUMERIC, SORT_STRING.

Additional arg's.

先实现指定多维数组一个字段排序

此处要求根据其中的一个字段来对数组进行排序,数组假设如下:

$array = array(

0=>array('id'=>8,'name'=>'Tom'),

1=>array('id'=>9,'name'=>'Peter'),

2=>array('id'=>5,'name'=>'Jack')

);

我们要根据二维数组的id值来排序,转换后的数组格式如下:

$array = array(

0=>array('id'=>5,'name'=>'Jack')

1=>array('id'=>8,'name'=>'Tom'),

2=>array('id'=>9,'name'=>'Peter')

);

要完成上述的转换,需要用到上面介绍的array_multisort函数,如下:

function sortArrByOneField(&$array, $field, $desc = false){

$fieldArr = array();

foreach ($array as $k => $v) {

$fieldArr[$k] = $v[$field];

}

$sort = $desc == false ? SORT_ASC : SORT_DESC;

array_multisort($fieldArr, $sort, $array);

}

通过将待排序数组的各个数组的$field保存在一位数组fieldArr中,在传入array_multisort中参与排序。其中field数组的值如下:

array(0=>8,1=>9,2=>5)

传入 array_multisort后,相当于对$field一维数组的排序,而后根据排序后的key重新构建传入的待排序数组。

实现多维数组的指定多个字段排序

上面的实例讲解了如何实现多维数组指定一个字段排序,但如果要实现指定多个字段来对数组进行排序该如何思考?

多个字段是几个?2个,3个或更多,所以这个不确定的因素需要排除。

我们先来看2指定2个字段进行排序的方案:

$arr = array(

'0' => array(

'id' => 3,

'age' => 27

),

'1' => array(

'id' => 5,

'age' => 50

),

'2' => array(

'id' => 4,

'age' => 44

),

'3' => array(

'id' => 3,

'age' => 78

)

);

foreach ( $arr as $key => $row ){

$id[$key] = $row ['id'];

$age[$key] = $row ['age'];

}

array_multisort($id, SORT_ASC, $age, SORT_DESC, $arr);

print_r($arr);

//result:Array([0]=>Array(['id']=>3 ['age']=>78) [1]=>Array(['id']=>3 ['age']=>27) [2]=>Array(['id']=>4 ['age']=>44) [3]=>Array(['id']=>5 ['age']=>50))

重构上述代码,只要采用php中的func_get_args函数,来动态获取传入的值,既可以解决多字段个数不确定的问题。实现如下:

$array1 = array(

0=>array('id'=>8,'name'=>'Apple','age'=> 18),

1=>array('id'=>8,'name'=>'Bed','age'=>17),

2=>array('id'=>5,'name'=>'Cos','age'=>16),

3=>array('id'=>5,'name'=>'Cos','age'=>14)

);

function sortArrByManyField(){

$args = func_get_args();

if(empty($args)){

return null;

}

$arr = array_shift($args);

if(!is_array($arr)){

throw new Exception("第一个参数不为数组");

}

foreach($args as $key => $field){

if(is_string($field)){

$temp = array();

foreach($arr as $index=> $val){

$temp[$index] = $val[$field];

}

$args[$key] = $temp;

}

}

$args[] = &$arr;//引用值

call_user_func_array('array_multisort',$args);

return array_pop($args);

}

$arr = sortArrByManyField($array1,'id',SORT_ASC,'name',SORT_ASC,'age',SORT_DESC);

print_r($arr);

运行结果如下:

array(4) {

[0]=>array(3) {

["id"]=>int(5)

["name"]=>string(3) "Cos"

["age"]=>int(16)

}

[1]=>array(3) {

["id"]=>int(5)

["name"]=>string(3) "Cos"

["age"]=>int(14)

}

[2]=>array(3) {

["id"]=>int(8)

["name"]=>string(5) "Apple"

["age"]=>int(18)

}

[3]=>array(3) {

["id"]=>int(8)

["name"]=>string(3) "Bed"

["age"]=>int(17)

}

}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值