本文实例讲述了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
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
|
/**
* 对查询结果集进行排序
* @access public
* @param array $list 查询结果
* @param string $field 排序的字段名
* @param string $sortby 排序类型 (asc正向排序 desc逆向排序 nat自然排序)
* @return array
*/
function list_sort_by( $list , $field , $sortby = 'asc' )
{
if ( is_array ( $list ))
{
$refer = $resultSet = array ();
foreach ( $list as $i => $data )
{
$refer [ $i ] = & $data [ $field ];
}
switch ( $sortby )
{
case 'asc' : // 正向排序
asort( $refer );
break ;
case 'desc' : // 逆向排序
arsort( $refer );
break ;
case 'nat' : // 自然排序
natcasesort( $refer );
break ;
}
foreach ( $refer as $key => $val )
{
$resultSet [] = & $list [ $key ];
}
return $resultSet ;
}
return false;
}
/**
* 例子
* 求:根据二维数组的id键值降序排列(也就是id越大的排在越前)?
*/
$list = array (
0 => array (
'id' => 1,
'name' => '第一'
),
1 => array (
'id' => 3,
'name' => '第三'
),
2 => array (
'id' => 2,
'name' => '第二'
),
3 => array (
'id' => 4,
'name' => '第四'
),
);
//解答
$new_list = list_sort_by( $list , 'id' , 'desc' );
print_r( $new_list );
|
运行结果如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
|
Array
(
[0] => Array
(
[id] => 4
[name] => 第四
)
[1] => Array
(
[id] => 3
[name] => 第三
)
[2] => Array
(
[id] => 2
[name] => 第二
)
[3] => Array
(
[id] => 1
[name] => 第一
)
)
|
希望本文所述对大家PHP程序设计有所帮助。