本文主要講述了用PHP語言實(shí)現(xiàn)數(shù)組按多個(gè)字段排序問題,附上代碼,有需要的朋友可以看一下。
題目:一個(gè)二維數(shù)組,需要按照庫存量排序,然后再按照門店距離排序。
發(fā)現(xiàn)了這樣一個(gè)這樣子的方法:
- $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(); // 獲取函數(shù)的參數(shù)的數(shù)組
- if(emptyempty($args)){
- return null;
- }
- $arr = array_shift($args);
- if(!is_array($arr)){
- throw new Exception("第一個(gè)參數(shù)不為數(shù)組");
- }
- 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);
結(jié)果如下:
- <span style="color: #008080;"> array(4) {<br> [0]=>array(3) {<br> ["id"]=>int(5)<br> ["name"]=>string(3) "Cos"<br> ["age"]=>int(16)<br> }<br> [1]=>array(3) {<br> ["id"]=>int(5)<br> ["name"]=>string(3) "Cos"<br> ["age"]=>int(14)<br> }<br> [2]=>array(3) {<br> ["id"]=>int(8)<br> ["name"]=>string(5) "Apple"<br> ["age"]=>int(18)<br> }<br> [3]=>array(3) {<br> ["id"]=>int(8)<br> ["name"]=>string(3) "Bed"<br> ["age"]=>int(17)<br> }<br> }</span><span style="color: #008080;"><br></span>
新聞熱點(diǎn)
疑難解答