java多维数组按照某一列排序,PHP实现二维数组按某列进行排序的方法
本文實(shí)例講述了PHP實(shí)現(xiàn)二維數(shù)組按某列進(jìn)行排序的方法。分享給大家供大家參考,具體如下:
/*
* 二維數(shù)組 按某列排序
* array_multisort($arr1,$arr2)
* 手冊 例子如下
*
*/
$data[] = array('volume' => 67, 'edition' => 2);
$data[] = array('volume' => 86, 'edition' => 1);
$data[] = array('volume' => 85, 'edition' => 6);
$data[] = array('volume' => 98, 'edition' => 2);
$data[] = array('volume' => 86, 'edition' => 6);
$data[] = array('volume' => 67, 'edition' => 7);
// 取得列的列表
foreach ($data as $key => $row) {
$volume[$key] = $row['volume'];
$edition[$key] = $row['edition'];
}
// 將數(shù)據(jù)根據(jù) volume 降序排列,根據(jù) edition 升序排列
// 把 $data 作為最后一個(gè)參數(shù),以通用鍵排序
array_multisort($volume, SORT_DESC, $edition, SORT_ASC, $data);
/*************************************/
/* 從上面的例子不難看出,array_multisort()函數(shù)
* 是將每一個(gè)二維數(shù)組的列作為 一個(gè)參數(shù)進(jìn)行排序
* 來達(dá)到整個(gè)數(shù)組的排序
*/
/*************************************/
function sigcol_arrsort($data,$col,$type=SORT_DESC){
if(is_array($data)){
$i=0;
foreach($data as $k=>$v){
if(key_exists($col,$v)){
$arr[$i] = $v[$col];
$i++;
}else{
continue;
}
}
}else{
return false;
}
array_multisort($arr,$type,$data);
return $data;
}
print_r(sigcol_arrsort($data,'edition',SORT_DESC));
/*說白了 原理就是:
新數(shù)組 原二維數(shù)組
2 array('volume' => 67, 'edition' => 2);
1 array('volume' => 86, 'edition' => 1);
6 array('volume' => 85, 'edition' => 6);
2 array('volume' => 98, 'edition' => 2);
6 array('volume' => 86, 'edition' => 6);
7 array('volume' => 67, 'edition' => 7);
這兩個(gè)數(shù)組的每一行都鎖在一起,新數(shù)組一旦變動(dòng)順序,
那么就會(huì)連帶每一行的二維數(shù)組也跟著變換順序 ,即新數(shù)組為參照物
相當(dāng)于查詢子句中的 order by
*/
運(yùn)行結(jié)果:
Array
(
[0] => Array
(
[volume] => 67
[edition] => 7
)
[1] => Array
(
[volume] => 85
[edition] => 6
)
[2] => Array
(
[volume] => 86
[edition] => 6
)
[3] => Array
(
[volume] => 67
[edition] => 2
)
[4] => Array
(
[volume] => 98
[edition] => 2
)
[5] => Array
(
[volume] => 86
[edition] => 1
)
)
希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。
總結(jié)
以上是生活随笔為你收集整理的java多维数组按照某一列排序,PHP实现二维数组按某列进行排序的方法的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 蔚来:阿尔卑斯全系车型采用800V方案
- 下一篇: php定界符号,PHP定界符的使用及注意