本文实例讲述了PHP实现的自定义数组排序函数与排序类。分享给大家供大家参考,具体如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
|
/*
* 二维数组自定义排序函数
* uasort($arr,function_name)
*
**/
$arr = array (
array ( 'a' =>1, 'b' => 'c' ),
array ( 'a' =>4, 'b' => 'a' ),
array ( 'a' =>5, 'b' => 'g' ),
array ( 'a' =>7, 'b' => 'f' ),
array ( 'a' =>6, 'b' => 'e' )
);
function compare_arr( $x , $y ){
if ( $x [ 'b' ]< $y [ 'b' ]){
return -1;
} else if ( $x [ 'b' ]> $y [ 'b' ]){
return 1;
} else {
return 0;
}
}
uasort( $arr , 'compare_arr' );
foreach ( $arr as $a ){
echo $a [ 'a' ]. '=>' . $a [ 'b' ]. '<br/>' ;
}
|
手册里的自定义排序类:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
|
class multiSort
{
var $key ; //key in your array
//排序函数 参数依次是 数组 待排列索引 排序类型
function run ( $myarray , $key_to_sort , $type_of_sort = '' )
{
$this ->key = $key_to_sort ;
if ( $type_of_sort == 'desc' )
uasort( $myarray , array ( $this , 'myreverse_compare' ));
else
uasort( $myarray , array ( $this , 'mycompare' ));
return $myarray ;
}
//正序
function mycompare( $x , $y )
{
if ( $x [ $this ->key] == $y [ $this ->key] )
return 0;
else if ( $x [ $this ->key] < $y [ $this ->key] )
return -1;
else
return 1;
}
//逆序
function myreverse_compare( $x , $y )
{
if ( $x [ $this ->key] == $y [ $this ->key] )
return 0;
else if ( $x [ $this ->key] > $y [ $this ->key] )
return -1;
else
return 1;
}
}
|
希望本文所述对大家PHP程序设计有所帮助。