PHP 多維數(shù)組排序(usort,uasort)
更新時(shí)間:2010年06月30日 17:51:42 作者:
當(dāng)我們想對多維數(shù)組進(jìn)行排序時(shí),多維數(shù)組的每個(gè)元素又是一數(shù)組類型,而兩個(gè)數(shù)組如何比較大???這是需要用戶自定義的(是按每個(gè)數(shù)組的第一元素比較還是…)。
數(shù)字索引數(shù)組:
bool usort( array &$array, callback $cmp_function )
usort函數(shù)對指定數(shù)組(參數(shù)1)按指定方式(參數(shù)2)進(jìn)行排序。
當(dāng)我們想對多維數(shù)組進(jìn)行排序時(shí),多維數(shù)組的每個(gè)元素又是一數(shù)組類型,而兩個(gè)數(shù)組如何比較大???這是需要用戶自定義的(是按每個(gè)數(shù)組的第一元素比較還是…)。
<?php
//定義多維數(shù)組
$a = array(
array("sky", "blue"),
array("apple", "red"),
array("tree", "green"));
//自定義數(shù)組比較函數(shù),按數(shù)組的第二個(gè)元素進(jìn)行比較。
function my_compare($a, $b) {
if ($a[1] < $b[1])
return -1;
else if ($a[1] == $b[1])
return 0;
else
return 1;
}
//排序
usort($a, 'my_compare');
//輸出結(jié)果
foreach($a as $elem) {
echo "$elem[0] : $elem[1]<br />";
}
?>
結(jié)果為:
sky : blue
tree : green
apple : red
關(guān)聯(lián)數(shù)組:
bool uasort(array &$array, callback $cmp_function)
bool uksort(array &$array, callback $cmp_function)
uasort, uksort用法與usort相同,其中uasort()對關(guān)聯(lián)數(shù)組的值(value)進(jìn)行排序,uksort()對關(guān)聯(lián)數(shù)組的關(guān)鍵字(key)進(jìn)行排序。
<?php
$a = array(
'Sunday' => array(0,'7th'),
'Friday' => array(5,'5th'),
'Tuesday'=> array(2,'2nd'));
function my_compare($a, $b) {
if ($a[1] < $b[1])
return -1;
else if ($a[1] == $b[1])
return 0;
else
return 1;
}
//按$a數(shù)組的值的第二個(gè)元素(7th,5th,2nd)進(jìn)行排序
uasort($a, 'my_compare');
foreach($a as $key => $value) {
echo "$key : $value[0] $value[1]<br />";
}
//按$a數(shù)組的關(guān)鍵字的第二個(gè)字符(r,u,u)進(jìn)行排序
uksort($a, 'my_compare');
foreach($a as $key => $value) {
echo "$key : $value[0] $value[1]<br />";
}
?>
結(jié)果為:
Tuesday : 2 2nd
Friday : 5 5th
Sunday : 0 7th
Friday : 5 5th
Sunday : 0 7th
Tuesday : 2 2nd
bool usort( array &$array, callback $cmp_function )
usort函數(shù)對指定數(shù)組(參數(shù)1)按指定方式(參數(shù)2)進(jìn)行排序。
當(dāng)我們想對多維數(shù)組進(jìn)行排序時(shí),多維數(shù)組的每個(gè)元素又是一數(shù)組類型,而兩個(gè)數(shù)組如何比較大???這是需要用戶自定義的(是按每個(gè)數(shù)組的第一元素比較還是…)。
復(fù)制代碼 代碼如下:
<?php
//定義多維數(shù)組
$a = array(
array("sky", "blue"),
array("apple", "red"),
array("tree", "green"));
//自定義數(shù)組比較函數(shù),按數(shù)組的第二個(gè)元素進(jìn)行比較。
function my_compare($a, $b) {
if ($a[1] < $b[1])
return -1;
else if ($a[1] == $b[1])
return 0;
else
return 1;
}
//排序
usort($a, 'my_compare');
//輸出結(jié)果
foreach($a as $elem) {
echo "$elem[0] : $elem[1]<br />";
}
?>
結(jié)果為:
復(fù)制代碼 代碼如下:
sky : blue
tree : green
apple : red
關(guān)聯(lián)數(shù)組:
bool uasort(array &$array, callback $cmp_function)
bool uksort(array &$array, callback $cmp_function)
uasort, uksort用法與usort相同,其中uasort()對關(guān)聯(lián)數(shù)組的值(value)進(jìn)行排序,uksort()對關(guān)聯(lián)數(shù)組的關(guān)鍵字(key)進(jìn)行排序。
復(fù)制代碼 代碼如下:
<?php
$a = array(
'Sunday' => array(0,'7th'),
'Friday' => array(5,'5th'),
'Tuesday'=> array(2,'2nd'));
function my_compare($a, $b) {
if ($a[1] < $b[1])
return -1;
else if ($a[1] == $b[1])
return 0;
else
return 1;
}
//按$a數(shù)組的值的第二個(gè)元素(7th,5th,2nd)進(jìn)行排序
uasort($a, 'my_compare');
foreach($a as $key => $value) {
echo "$key : $value[0] $value[1]<br />";
}
//按$a數(shù)組的關(guān)鍵字的第二個(gè)字符(r,u,u)進(jìn)行排序
uksort($a, 'my_compare');
foreach($a as $key => $value) {
echo "$key : $value[0] $value[1]<br />";
}
?>
結(jié)果為:
Tuesday : 2 2nd
Friday : 5 5th
Sunday : 0 7th
Friday : 5 5th
Sunday : 0 7th
Tuesday : 2 2nd
相關(guān)文章
PHP 數(shù)組遍歷方法大全(foreach,list,each)
php下最靈活的東西都是數(shù)組,很多數(shù)據(jù)都是通過數(shù)組的方式顯示,這里整理下數(shù)組的遍歷方法,大家可以根據(jù)需要選用。2010-06-06
PHP 訪問數(shù)據(jù)庫配置通用方法(json)
目的是通過通用類訪問配置文件的方式,提供對數(shù)據(jù)庫連接的動(dòng)態(tài)獲取和設(shè)置,使開發(fā)時(shí)和生產(chǎn)應(yīng)用時(shí)都能夠提供靈活的、簡化的、解耦的操作方式,需要的朋友可以參考下2018-05-05
php中call_user_func函數(shù)使用注意事項(xiàng)
這篇文章主要介紹了php中call_user_func函數(shù)使用注意事項(xiàng),較為詳細(xì)的講述了call_user_func函數(shù)的用法實(shí)例與注意事項(xiàng),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2014-11-11
學(xué)習(xí)php設(shè)計(jì)模式 php實(shí)現(xiàn)模板方法模式
這篇文章主要介紹了php設(shè)計(jì)模式中的模板方法模式,使用php實(shí)現(xiàn)模板方法模式,感興趣的小伙伴們可以參考一下2015-12-12
Zend?Framework框架等常用php框架中存在的問題
這篇文章主要介紹了Zend?Framework框架等常用php框架中存在的問題2008-01-01

