php 數(shù)組排序 array_multisort與uasort的區(qū)別
更新時(shí)間:2011年03月24日 00:40:27 作者:
其實(shí),簡單的說兩者的最重要的區(qū)別:array_multisort()排序之后,原數(shù)組“鍵”丟失。uasort()排序之后,保留原來的“鍵”。
Example:(簡練)
uasort($arr,create_function('$a, $b','return $a[\'line_num\']<$b[\'line_num\'];'));
*************函數(shù)定義和語法*************
array_multisort
(PHP4 >= 4.0b4)
array_multisort --- 排序復(fù)合或多樣尺寸的數(shù)組
語法 : bool array_multisort (array ar1 [,mixed arg [,mixed ...[,array...]]])
說明 :
Array_multisort( )能用來立刻將數(shù)個(gè)數(shù)組或多樣尺寸(multi-dimensional)數(shù)組排序。
輸入的數(shù)組被看作是表格(table)的欄位,依照列(rows)將它排序,這類似于SQL ORDER BY clause的功能,第一個(gè)數(shù)組是首要(primary)排序的數(shù)組,此數(shù)組中的列(值)以下一個(gè)輸入的數(shù)組對照相同的排序。
這個(gè)函數(shù)的引數(shù)結(jié)構(gòu)是個(gè)獨(dú)特(unusual)位元,但是是可變通的。第一個(gè)引數(shù)必定是個(gè)數(shù)組,隨后的引數(shù)可以是個(gè)數(shù)組或是下個(gè)列表的排序旗標(biāo)(flag)之一。
排序順序旗標(biāo) :
SORT_ASC - 排序成上升的順序
SORT_DESC - 排序成下降的順序
排序型態(tài)旗標(biāo) :
SORT_REGULAR - 正常的比較項(xiàng)目
SORT_NUMERIC - 以數(shù)字比較項(xiàng)目
SORT_STRING - 看作是字符串來比較項(xiàng)目
不能使用二個(gè)相同型態(tài)的旗標(biāo)指定在各各數(shù)組之后,排序的旗標(biāo)指定在數(shù)組引數(shù)的后面,只對此數(shù)組起作用,其它的將重設(shè)為預(yù)設(shè)的SORT_ASC和SORT_REGULAR在數(shù)組引數(shù)之后。
成功則傳回true,失敗則傳回false。
*************函數(shù)定義和語法*************
uasort()
函數(shù)使用用戶自定義的比較函數(shù)對數(shù)組排序,并保持索引關(guān)聯(lián)(不為元素分配新的鍵)。
如果成功則返回 TRUE,否則返回 FALSE。
該函數(shù)主要用于對那些單元順序很重要的結(jié)合數(shù)組進(jìn)行排序。
語法
uasort(array,sorttype)參數(shù) 描述
array 必需。規(guī)定要排序的數(shù)組。
function 必需。用戶自定義的函數(shù)。
函數(shù)必須設(shè)計(jì)為返回 -1, 0, 或 1,并應(yīng)該接受兩個(gè)供比較的參數(shù),同時(shí)以類似下面這樣的方式來工作:
如果 a = b, 返回 0
如果 a < b, 返回 1
如果 a > b, 返回 -1
PHP uasort() 函數(shù)
定義和用法
uasort() 函數(shù)使用用戶自定義的比較函數(shù)對數(shù)組排序,并保持索引關(guān)聯(lián)(不為元素分配新的鍵)。
如果成功則返回 TRUE,否則返回 FALSE。
該函數(shù)主要用于對那些單元順序很重要的結(jié)合數(shù)組進(jìn)行排序。
語法
uasort(array,sorttype)參數(shù) 描述
array 必需。規(guī)定要排序的數(shù)組。
function 必需。用戶自定義的函數(shù)。
函數(shù)必須設(shè)計(jì)為返回 -1, 0, 或 1,并應(yīng)該接受兩個(gè)供比較的參數(shù),同時(shí)以類似下面這樣的方式來工作:
如果 a = b, 返回 0
如果 a < b, 返回 1
如果 a > b, 返回 -1
例子
<?php
function my_sort($a, $b)
{
if ($a == $b) return 0;
return ($a > $b) ? -1 : 1;
}
$people = array("Swanson" => "Joe",
"Griffin" => "Peter", "Quagmire" => "Glenn",
"swanson" => "joe", "griffin" => "peter",
"quagmire" => "glenn");
uasort($people, "my_sort");
print_r ($people);
?>
輸出:
Array
(
[griffin] => peter
[swanson] => joe
[quagmire] => glenn
[Griffin] => Peter
[Swanson] => Joe
[Quagmire] => Glenn
)
uasort($arr,create_function('$a, $b','return $a[\'line_num\']<$b[\'line_num\'];'));
*************函數(shù)定義和語法*************
array_multisort
(PHP4 >= 4.0b4)
array_multisort --- 排序復(fù)合或多樣尺寸的數(shù)組
語法 : bool array_multisort (array ar1 [,mixed arg [,mixed ...[,array...]]])
說明 :
Array_multisort( )能用來立刻將數(shù)個(gè)數(shù)組或多樣尺寸(multi-dimensional)數(shù)組排序。
輸入的數(shù)組被看作是表格(table)的欄位,依照列(rows)將它排序,這類似于SQL ORDER BY clause的功能,第一個(gè)數(shù)組是首要(primary)排序的數(shù)組,此數(shù)組中的列(值)以下一個(gè)輸入的數(shù)組對照相同的排序。
這個(gè)函數(shù)的引數(shù)結(jié)構(gòu)是個(gè)獨(dú)特(unusual)位元,但是是可變通的。第一個(gè)引數(shù)必定是個(gè)數(shù)組,隨后的引數(shù)可以是個(gè)數(shù)組或是下個(gè)列表的排序旗標(biāo)(flag)之一。
排序順序旗標(biāo) :
SORT_ASC - 排序成上升的順序
SORT_DESC - 排序成下降的順序
排序型態(tài)旗標(biāo) :
SORT_REGULAR - 正常的比較項(xiàng)目
SORT_NUMERIC - 以數(shù)字比較項(xiàng)目
SORT_STRING - 看作是字符串來比較項(xiàng)目
不能使用二個(gè)相同型態(tài)的旗標(biāo)指定在各各數(shù)組之后,排序的旗標(biāo)指定在數(shù)組引數(shù)的后面,只對此數(shù)組起作用,其它的將重設(shè)為預(yù)設(shè)的SORT_ASC和SORT_REGULAR在數(shù)組引數(shù)之后。
成功則傳回true,失敗則傳回false。
*************函數(shù)定義和語法*************
uasort()
函數(shù)使用用戶自定義的比較函數(shù)對數(shù)組排序,并保持索引關(guān)聯(lián)(不為元素分配新的鍵)。
如果成功則返回 TRUE,否則返回 FALSE。
該函數(shù)主要用于對那些單元順序很重要的結(jié)合數(shù)組進(jìn)行排序。
語法
uasort(array,sorttype)參數(shù) 描述
array 必需。規(guī)定要排序的數(shù)組。
function 必需。用戶自定義的函數(shù)。
函數(shù)必須設(shè)計(jì)為返回 -1, 0, 或 1,并應(yīng)該接受兩個(gè)供比較的參數(shù),同時(shí)以類似下面這樣的方式來工作:
如果 a = b, 返回 0
如果 a < b, 返回 1
如果 a > b, 返回 -1
PHP uasort() 函數(shù)
定義和用法
uasort() 函數(shù)使用用戶自定義的比較函數(shù)對數(shù)組排序,并保持索引關(guān)聯(lián)(不為元素分配新的鍵)。
如果成功則返回 TRUE,否則返回 FALSE。
該函數(shù)主要用于對那些單元順序很重要的結(jié)合數(shù)組進(jìn)行排序。
語法
uasort(array,sorttype)參數(shù) 描述
array 必需。規(guī)定要排序的數(shù)組。
function 必需。用戶自定義的函數(shù)。
函數(shù)必須設(shè)計(jì)為返回 -1, 0, 或 1,并應(yīng)該接受兩個(gè)供比較的參數(shù),同時(shí)以類似下面這樣的方式來工作:
如果 a = b, 返回 0
如果 a < b, 返回 1
如果 a > b, 返回 -1
例子
復(fù)制代碼 代碼如下:
<?php
function my_sort($a, $b)
{
if ($a == $b) return 0;
return ($a > $b) ? -1 : 1;
}
$people = array("Swanson" => "Joe",
"Griffin" => "Peter", "Quagmire" => "Glenn",
"swanson" => "joe", "griffin" => "peter",
"quagmire" => "glenn");
uasort($people, "my_sort");
print_r ($people);
?>
輸出:
復(fù)制代碼 代碼如下:
Array
(
[griffin] => peter
[swanson] => joe
[quagmire] => glenn
[Griffin] => Peter
[Swanson] => Joe
[Quagmire] => Glenn
)
您可能感興趣的文章:
- PHP 數(shù)組排序方法總結(jié) 推薦收藏
- php中二維數(shù)組排序問題方法詳解
- array_multisort實(shí)現(xiàn)PHP多維數(shù)組排序示例講解
- php簡單實(shí)現(xiàn)多維數(shù)組排序的方法
- PHP 冒泡排序 二分查找 順序查找 二維數(shù)組排序算法函數(shù)的詳解
- php不用內(nèi)置函數(shù)對數(shù)組排序的兩個(gè)算法代碼
- php關(guān)于array_multisort多維數(shù)組排序的使用說明
- PHP數(shù)組排序之sort、asort與ksort用法實(shí)例
- PHP 簡單數(shù)組排序?qū)崿F(xiàn)代碼
- PHP常見數(shù)組排序方法小結(jié)
相關(guān)文章
php使用mysqli向數(shù)據(jù)庫添加數(shù)據(jù)的方法
這篇文章主要介紹了php使用mysqli向數(shù)據(jù)庫添加數(shù)據(jù)的方法,實(shí)例分析了php使用mysqli進(jìn)行數(shù)據(jù)庫操作的技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2015-03-03
php中經(jīng)典方法實(shí)現(xiàn)判斷多維數(shù)組是否為空
傳統(tǒng)的判斷數(shù)組為空 一般用count或者key 而且多維數(shù)組的話很麻煩2011-10-10
linux下的php-fpm參數(shù)配置介紹與參數(shù)優(yōu)化說明
本文主要講解了在linux下php-fpm一些重要參數(shù)的中文詳細(xì)說明,并詳細(xì)介紹了php-fpm關(guān)于性能方面的參數(shù)優(yōu)化介紹2017-12-12
php實(shí)現(xiàn)微信公眾號主動(dòng)推送消息
這篇文章主要介紹了php實(shí)現(xiàn)微信公眾號主動(dòng)推送消息的方法,PHP版微信公共平臺(tái)消息主動(dòng)推送,突破訂閱號一天只能發(fā)送一條信息限制,需要的朋友可以參考下2015-12-12
php中選擇什么接口(mysql、mysqli)訪問mysql
我們知道,mysqli是PHP 5中新提供的MySQL接口,此接口使用了面向?qū)ο蟮乃枷?。使用mysqli接口的代碼可讀性更強(qiáng),其執(zhí)行效率比mysql接口高2013-02-02
PHP轉(zhuǎn)換文件夾下所有文件編碼的實(shí)現(xiàn)代碼
本篇文章是對PHP轉(zhuǎn)換文件夾下所有文件編碼的實(shí)現(xiàn)代碼進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06
php實(shí)現(xiàn)在限定區(qū)域里自動(dòng)調(diào)整字體大小的類實(shí)例
這篇文章主要介紹了php實(shí)現(xiàn)在限定區(qū)域里自動(dòng)調(diào)整字體大小的類,實(shí)例分析了php操作圖片及字體的技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-04-04

