php比較多維數(shù)組中值的大小排序?qū)崿F(xiàn)代碼
更新時間:2012年09月08日 00:09:37 作者:
php中根據(jù)數(shù)組的鍵(key)進行比較,排序,有很多內(nèi)置函數(shù)可以輕松解決,如krsort(), ksort()等。如果是根據(jù)數(shù)組的值(value)進行比較就麻煩一些
如果值沒有重復(fù)的情況,可以先用array_flip()來交換鍵和值,然后krsort(),最后再array_flip()交換回來,就可以比較大小了。如果要截取數(shù)組,可用array_slice()。
如果有值重復(fù)的情況,就要用到一些排序算法了,不過php有很強大的函數(shù)uasort(),使用自定義的比較函數(shù)對數(shù)組中的值進行排序并保持索引關(guān)聯(lián),usort()則會重建索引。
function cmp($a, $b){
if ($a["vote_num"] == $b["vote_num"]) {
return 0;
}
return ($a["vote_num"] > $b["vote_num"]) ? -1 : 1;
}
$arr = Array
(
0 => Array
(
o_id => 1861,
o_name => 2,
o_pic => 'http://g.jb51.net/image.gif' ,
o_detail => 人人,
vote_num => 1
),
1 => Array
(
o_id => 1844,
o_name => 芭比,
o_pic => 'http://upload.jb51.net/game_image/dfxxz/dfVIP.files/shenxiandao.jpg',
o_detail => 也是美女呢,
vote_num => 2
),
2 => Array
(
o_id => 1843,
o_name => 程程,
o_pic => 'http://g.jb51.net./upload_img/2011-06/31554_4d0088da7a61ad9c8c02a530be94d98e.png',
o_detail => 美女哦,
vote_num => 3
)
);
uasort($arr, ”cmp“);
echo ‘< pre style="text-align:left" >';
print_r ($arr);
echo ‘< / pre >';
返回
Array
(
[2] => Array
(
[o_id] => 1843
[o_name] => 程程
[o_pic] => http://g.jb51.net./upload_img/2011-06/31554_4d0088da7a61ad9c8c02a530be94d98e.png
[o_detail] => 美女哦
[vote_num] => 3
)
[1] => Array
(
[o_id] => 1844
[o_name] => 芭比
[o_pic] => http://upload.jb51.net/game_image/dfxxz/dfVIP.files/shenxiandao.jpg
[o_detail] => 也是美女呢
[vote_num] => 2
)
[0] => Array
(
[o_id] => 1861
[o_name] => 2
[o_pic] => http://g.jb51.net/image.gif
[o_detail] => 人人
[vote_num] => 1
)
)
如果有值重復(fù)的情況,就要用到一些排序算法了,不過php有很強大的函數(shù)uasort(),使用自定義的比較函數(shù)對數(shù)組中的值進行排序并保持索引關(guān)聯(lián),usort()則會重建索引。
復(fù)制代碼 代碼如下:
function cmp($a, $b){
if ($a["vote_num"] == $b["vote_num"]) {
return 0;
}
return ($a["vote_num"] > $b["vote_num"]) ? -1 : 1;
}
$arr = Array
(
0 => Array
(
o_id => 1861,
o_name => 2,
o_pic => 'http://g.jb51.net/image.gif' ,
o_detail => 人人,
vote_num => 1
),
1 => Array
(
o_id => 1844,
o_name => 芭比,
o_pic => 'http://upload.jb51.net/game_image/dfxxz/dfVIP.files/shenxiandao.jpg',
o_detail => 也是美女呢,
vote_num => 2
),
2 => Array
(
o_id => 1843,
o_name => 程程,
o_pic => 'http://g.jb51.net./upload_img/2011-06/31554_4d0088da7a61ad9c8c02a530be94d98e.png',
o_detail => 美女哦,
vote_num => 3
)
);
uasort($arr, ”cmp“);
echo ‘< pre style="text-align:left" >';
print_r ($arr);
echo ‘< / pre >';
返回
復(fù)制代碼 代碼如下:
Array
(
[2] => Array
(
[o_id] => 1843
[o_name] => 程程
[o_pic] => http://g.jb51.net./upload_img/2011-06/31554_4d0088da7a61ad9c8c02a530be94d98e.png
[o_detail] => 美女哦
[vote_num] => 3
)
[1] => Array
(
[o_id] => 1844
[o_name] => 芭比
[o_pic] => http://upload.jb51.net/game_image/dfxxz/dfVIP.files/shenxiandao.jpg
[o_detail] => 也是美女呢
[vote_num] => 2
)
[0] => Array
(
[o_id] => 1861
[o_name] => 2
[o_pic] => http://g.jb51.net/image.gif
[o_detail] => 人人
[vote_num] => 1
)
)
您可能感興趣的文章:
- PHP 多維數(shù)組的排序問題 根據(jù)二維數(shù)組中某個項排序
- array_multisort實現(xiàn)PHP多維數(shù)組排序示例講解
- PHP 多維數(shù)組排序(usort,uasort)
- php簡單實現(xiàn)多維數(shù)組排序的方法
- php中多維數(shù)組按指定value排序的實現(xiàn)代碼
- PHP 多維數(shù)組排序?qū)崿F(xiàn)代碼
- php關(guān)于array_multisort多維數(shù)組排序的使用說明
- php中array_multisort對多維數(shù)組排序的方法
- PHP編程實現(xiàn)多維數(shù)組按照某個鍵值排序的方法小結(jié)【2種方法】
- php實現(xiàn)多維數(shù)組排序的方法示例
- PHP實現(xiàn)的多維數(shù)組排序算法分析
相關(guān)文章
PHP實現(xiàn)獲取毫秒時間戳的方法【使用microtime()函數(shù)】
這篇文章主要介紹了PHP實現(xiàn)獲取毫秒時間戳的方法,結(jié)合實例形式分析了php使用microtime()函數(shù)獲取、轉(zhuǎn)換毫秒級時間戳的相關(guān)操作技巧,需要的朋友可以參考下2019-03-03解決PHP在DOS命令行下卻無法鏈接MySQL的技術(shù)筆記
前段時間,由于要用 php 進行 Shell 編程時,碰到了 PHP 在 WEB 下可以連接 MySQL 而在 DOS COMMAND 命令行下卻連接失敗的問題。2010-12-12