本文實(shí)例講述了PHP實(shí)現(xiàn)二維數(shù)組按照指定的字段進(jìn)行排序算法。分享給大家供大家參考,具體如下:
遇到問(wèn)題:把兩個(gè)數(shù)組用php自帶的array_merge()
函數(shù)合并之后,想按照兩個(gè)數(shù)組中共有的'post_time'字段為新數(shù)組進(jìn)行排序
解決辦法:通過(guò)查閱官方手冊(cè),得知有array_multisort()
這個(gè)函數(shù),可以對(duì)多個(gè)數(shù)組或多維數(shù)組進(jìn)行排序,返回排序之后的數(shù)組,其中字符串鍵名將被保留,但是數(shù)字鍵名將被重新索引,從 0 開(kāi)始,并以 1 遞增。
下面封裝了這個(gè)函數(shù),便于調(diào)用:
/**
* 二維數(shù)組按照指定字段進(jìn)行排序
* @params array $array 需要排序的數(shù)組
* @params string $field 排序的字段
* @params string $sort 排序順序標(biāo)志 SORT_DESC 降序;SORT_ASC 升序
*/
function arraySequence($array, $field, $sort = 'SORT_DESC') {
$arrSort = array();
foreach ($array as $uniqid => $row) {
foreach ($row as $key => $value) {
$arrSort[$key][$uniqid] = $value;
}
}
array_multisort($arrSort[$field], constant($sort), $array);
return $array;
}
//測(cè)試:
$arrDemo = array(
array('name'=>'Jack','age'=>'22'),
array('name'=>'Tom','age'=>'24'),
array('name'=>'Green','age'=>'21'),
array('name'=>'Ben','age'=>'23'),);
$arrDemo = arraySequence($arrDemo,'age');
print_r($arrDemo);
運(yùn)行結(jié)果:
Array
(
[0] => Array
(
[name] => Tom
[age] => 24
)
[1] => Array
(
[name] => Ben
[age] => 23
)
[2] => Array
(
[name] => Jack
[age] => 22
)
[3] => Array
(
[name] => Green
[age] => 21
)
)
新增:按照指定的多個(gè)字段排序
/**
* 二維數(shù)組按照指定的多個(gè)字段進(jìn)行排序
*
* 調(diào)用示例:sortArrByManyField($arr,'id',SORT_ASC,'age',SORT_DESC);
*/
function sortArrByManyField(){
$args = func_get_args();
if(empty($args)){
return null;
}
$arr = array_shift($args);
if(!is_array($arr)){
throw new Exception("第一個(gè)參數(shù)應(yīng)為數(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);
}
//測(cè)試:
$arrDemo = array(
array('name'=>'Jack','age'=>'22'),
array('name'=>'Tom','age'=>'24'),
array('name'=>'Green','age'=>'21'),
array('name'=>'Ben','age'=>'23'),);
$arrDemo = sortArrByManyField($arrDemo,'age');
print_r($arrDemo);
運(yùn)行結(jié)果:
Array
(
[0] => Array
(
[name] => Green
[age] => 21
)
[1] => Array
(
[name] => Jack
[age] => 22
)
[2] => Array
(
[name] => Ben
[age] => 23
)
[3] => Array
(
[name] => Tom
[age] => 24
)
)
PS:這里再為大家推薦一款關(guān)于排序的演示工具供大家參考:
在線動(dòng)畫(huà)演示插入/選擇/冒泡/歸并/希爾/快速排序算法過(guò)程工具:
http://tools.jb51.net/aideddesign/paixu_ys
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專(zhuān)題:《PHP數(shù)組(Array)操作技巧大全》、《php排序算法總結(jié)》、《PHP數(shù)據(jù)結(jié)構(gòu)與算法教程》、《php程序設(shè)計(jì)算法總結(jié)》、《php字符串(string)用法總結(jié)》及《PHP常用遍歷算法與技巧總結(jié)》
希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。
您可能感興趣的文章:- PHP實(shí)現(xiàn)的AES 128位加密算法示例
- PHP實(shí)現(xiàn)基于3DES算法加密解密字符串示例
- PHP實(shí)現(xiàn)二維數(shù)組中的查找算法小結(jié)
- PHP封裝的非對(duì)稱(chēng)加密RSA算法示例
- 50個(gè)優(yōu)秀經(jīng)典PHP算法大集合 附源碼