|
關(guān)于排序一般我們都是通過數(shù)據(jù)庫或者nosql(eg:redis)先排好序然后輸出到程序里直接使用,但是有些時(shí)候我們需要通過php直接來對(duì)數(shù)組進(jìn)行排序,而在php里存儲(chǔ)數(shù)據(jù)用到最多的就是對(duì)象和數(shù)組,但處理較多的就是數(shù)組,因?yàn)橛蟹浅XS富的內(nèi)置函數(shù)庫(其實(shí)對(duì)象一定程度上也可以理解為是數(shù)組),這些函數(shù)庫很大程度上可以幫助我們實(shí)現(xiàn)某些功能。常用的系統(tǒng)函數(shù)有sort、asort、arsort、ksort、krsort等等,這里我主要說下對(duì)二維數(shù)組的排序,兩種方法:
一、用php自帶array_multisort函數(shù)排序
復(fù)制代碼 代碼如下:
<?php
$data = array();
$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'];
}
array_multisort($volume, SORT_DESC, $edition, SORT_ASC, $data);
print_r($data);
?>
輸出結(jié)果:
復(fù)制代碼 代碼如下:Array
(
[0] => Array
(
[volume] => 98
[edition] => 2
)
[1] => Array
(
[volume] => 86
[edition] => 1
)
[2] => Array
(
[volume] => 86
[edition] => 6
)
[3] => Array
(
[volume] => 85
[edition] => 6
)
[4] => Array
(
[volume] => 67
[edition] => 2
)
[5] => Array
(
[volume] => 67
[edition] => 7
)
)
關(guān)于array_multisort官方文檔也有比較詳細(xì)的說明:http://www.php.NET/manual/zh/function.array-multisort.php
二、自定義函數(shù)排序1
復(fù)制代碼 代碼如下:
<?php
$data = array();
$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'];
}
$ret = arraySort($data, 'volume', 'desc');
print_r($ret);
/**
* @desc arraySort php二維數(shù)組排序 按照指定的key 對(duì)數(shù)組進(jìn)行排序
* @param array $arr 將要排序的數(shù)組
* @param string $keys 指定排序的key
* @param string $type 排序類型 asc | desc
* @return array
*/
function arraySort($arr, $keys, $type = 'asc') {
$keysvalue = $new_array = array();
foreach ($arr as $k => $v){
$keysvalue[$k] = $v[$keys];
}
$type == 'asc' ? asort($keysvalue) : arsort($keysvalue);
reset($keysvalue);
foreach ($keysvalue as $k => $v) {
$new_array[$k] = $arr[$k];
}
return $new_array;
}
?>
輸出結(jié)果:
復(fù)制代碼 代碼如下:Array
(
[3] => Array
(
[volume] => 98
[edition] => 2
)
[4] => Array
(
[volume] => 86
[edition] => 6
)
[1] => Array
(
[volume] => 86
[edition] => 1
)
[2] => Array
(
[volume] => 85
[edition] => 6
)
[5] => Array
(
[volume] => 67
[edition] => 7
)
[0] => Array
(
[volume] => 67
[edition] => 2
)
)
這個(gè)自定義函數(shù)與系統(tǒng)函數(shù)的一個(gè)區(qū)別就是:自定義函數(shù)只支持針對(duì)某一個(gè)key的排序,如果要支持多個(gè)key的排序需要執(zhí)行多次; 而系統(tǒng)函數(shù)array_multisort可以一次性對(duì)多個(gè)key且可以指定多個(gè)排序規(guī)則,系統(tǒng)函數(shù)還是相當(dāng)強(qiáng)大的,推薦使用系統(tǒng)函數(shù),畢竟是C底層實(shí)現(xiàn)的,這里只是舉例說明如果通過自定義函數(shù)來對(duì)數(shù)組進(jìn)行排序,當(dāng)然這個(gè)自定義函數(shù)也可以繼續(xù)擴(kuò)展來支持更多的排序規(guī)則。在取排名、排行榜、成績(jī)等場(chǎng)景中用到的還是非常多的。
三、自定義函數(shù)排序2
以下函數(shù)是對(duì)一個(gè)給定的二維數(shù)組按照指定的鍵值進(jìn)行排序,先看函數(shù)定義:
復(fù)制代碼 代碼如下:
function array_sort($arr,$keys,$type='asc'){
$keysvalue = $new_array = array();
foreach ($arr as $k=>$v){
$keysvalue[$k] = $v[$keys];
}
if($type == 'asc'){
asort($keysvalue);
}else{
arsort($keysvalue);
}
reset($keysvalue);
foreach ($keysvalue as $k=>$v){
$new_array[$k] = $arr[$k];
}
return $new_array;
}
它可以對(duì)二維數(shù)組按照指定的鍵值進(jìn)行排序,也可以指定升序或降序排序法(默認(rèn)為升序),用法示例:
復(fù)制代碼 代碼如下:
$array = array(
array('name'=>'手機(jī)','brand'=>'諾基亞','price'=>1050),
array('name'=>'筆記本電腦','brand'=>'lenovo','price'=>4300),
array('name'=>'剃須刀','brand'=>'飛利浦','price'=>3100),
array('name'=>'跑步機(jī)','brand'=>'三和松石','price'=>4900),
array('name'=>'手表','brand'=>'卡西歐','price'=>960),
array('name'=>'液晶電視','brand'=>'索尼','price'=>6299),
array('name'=>'激光打印機(jī)','brand'=>'惠普','price'=>1200)
);
$ShoppingList = array_sort($array,'price');
print_r($ShoppingList);
上面是對(duì)$array這個(gè)二維數(shù)組按照'price'從低到高的排序。
php技術(shù):PHP二維數(shù)組排序的3種方法和自定義函數(shù)分享,轉(zhuǎn)載需保留來源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。