PHP數(shù)組排序函數(shù)合集 以及它們之間的聯(lián)系分析
更新時(shí)間:2013年06月27日 16:30:21 作者:
本篇文章是對(duì)PHP數(shù)組排序函數(shù)合集以及它們之間的聯(lián)系進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
下邊提到的幾個(gè)數(shù)組函數(shù)的排序有一些共性:
1 數(shù)組被作為排序函數(shù)的參數(shù),排序以后,數(shù)組本身就發(fā)生了改變,函數(shù)的返回值為bool類型。
2 函數(shù)名中出現(xiàn)單a表示association,含義為,在按值排序的過(guò)程中,保持key=>value的對(duì)應(yīng)關(guān)系不變
3 函數(shù)名中出現(xiàn)單k表示key,含義為,在按值排序的過(guò)程中按照數(shù)組key而不是數(shù)組的值排序
4 函數(shù)名中出現(xiàn)單r的表示reverse,含義為,按照跟不加r的相反的順序排列
5 函數(shù)名中出現(xiàn)單u的表示user-defined,含義為,使用用戶自定義函數(shù)排序,如果函數(shù)的邏輯是參數(shù)1<參數(shù)2返回負(fù)數(shù),則按照升序排列(p1小2返負(fù)升)。
--------------------sort函數(shù)升序排序--------------------------------
bool sort ( array &$array [, int $sort_flags= SORT_REGULAR ] )
<?php
$fruits = array("lemon", "orange", "banana", "apple");
sort($fruits);
var_dump($fruits);
?>
結(jié)果:
array
0 =>
string
'apple' (length=5)
1 =>
string
'banana' (length=6)
2 =>
string
'lemon' (length=5)
3 =>
string
'orange' (length=6)
--------------------rsort降序排列--------------------
<?php
$fruits = array("lemon", "orange", "banana", "apple");
rsort($fruits);
var_dump($fruits);
?>
結(jié)果:
array
0 =>
string
'orange' (length=6)
1 =>
string
'lemon' (length=5)
2 =>
string
'banana' (length=6)
3 =>
string
'apple' (length=5)
---------------asort按照二維數(shù)組值的升序排列(保持key=>value的關(guān)聯(lián)關(guān)系)-----------
<?php
$fruits = array("d" => "lemon", "a" => "orange", "b" => "banana", "c" => "apple");
asort($fruits);
var_dump($fruits);
?>
結(jié)果:
array
'c' =>
string
'apple' (length=5)
'b' =>
string
'banana' (length=6)
'd' =>
string
'lemon' (length=5)
'a' =>
string
'orange' (length=6)
---------arsort按照二維數(shù)組值的降序排列(保持key=>value的關(guān)聯(lián)關(guān)系)---------
<?php
$fruits = array("d" => "lemon", "a" => "orange", "b" => "banana", "c" => "apple");
arsort($fruits);
var_dump($fruits);
?>
結(jié)果
array
'a' =>
string
'orange' (length=6)
'd' =>
string
'lemon' (length=5)
'b' =>
string
'banana' (length=6)
'c' =>
string
'apple' (length=5)
--------------------ksort按照數(shù)組的key升序排列--------------
<?php
$fruits = array("d"=>"lemon", "a"=>"orange", "b"=>"banana", "c"=>"apple");
ksort($fruits);
var_dump($fruits);
?>
結(jié)果
array
'a' =>
string
'orange' (length=6)
'b' =>
string
'banana' (length=6)
'c' =>
string
'apple' (length=5)
'd' =>
string
'lemon' (length=5)
---------------------krsort按照數(shù)組key的降序排列-----------------------
<?php
$fruits = array("d"=>"lemon", "a"=>"orange", "b"=>"banana", "c"=>"apple");
krsort($fruits);
var_dump($fruits);
?>
array
'd' =>
string
'lemon' (length=5)
'c' =>
string
'apple' (length=5)
'b' =>
string
'banana' (length=6)
'a' =>
string
'orange' (length=6)
----------------usort函數(shù)按照用戶自定義的函數(shù)排序----------------
<?php
function cmp($a, $b)
{
if ($a == $b) {
return 0;
}
return ($a < $b) ? -1 : 1;
}
$a = array(3, 2, 5, 6, 1);
usort($a, "cmp");
var_dump($a);
?>
結(jié)果:
array
0 =>
int
1
1 =>
int
2
2 =>
int
3
3 =>
int
5
4 =>
int
6
-----------------uksort使用自定義函數(shù)按照數(shù)組的key排序-----------------
<?php
function cmp($a, $b)
{
$a = preg_replace('@^(a|an|the) @', '', $a);
$b = preg_replace('@^(a|an|the) @', '', $b);
return strcasecmp($a, $b);
}
$a = array("John" => 1, "the Earth" => 2, "an apple" => 3, "a banana" => 4);
uksort($a, "cmp");
var_dump($a);
?>
結(jié)果:
array
'an apple' =>
int
3
'a banana' =>
int
4
'the Earth' =>
int
2
'John' =>
int
1
--------------uasort將數(shù)組用自定義函數(shù)按照value排序,保持索引關(guān)系不變---------
<?php
// Comparison function
function cmp($a, $b) {
if ($a == $b) {
return 0;
}
return ($a < $b) ? -1 : 1;
}
// Array to be sorted
$array = array('a' => 4, 'b' => 8, 'c' => -1, 'd' => -9, 'e' => 2, 'f' => 5, 'g' => 3, 'h' => -4);
var_dump($array);
// Sort and print the resulting array
uasort($array, 'cmp');
var_dump($array);
?>
結(jié)果:
array
'a' =>
int
4
'b' =>
int
8
'c' =>
int
-1
'd' =>
int
-9
'e' =>
int
2
'f' =>
int
5
'g' =>
int
3
'h' =>
int
-4
array
'd' =>
int
-9
'h' =>
int
-4
'c' =>
int
-1
'e' =>
int
2
'g' =>
int
3
'a' =>
int
4
'f' =>
int
5
'b' =>
int
8
-------------------array_multisort排序多個(gè)數(shù)組或多維數(shù)組---------
<?php
$ar = array(
array("10", 11, 100, 100, "a"),
array( 1, 2, "2", 3, 1)
);
array_multisort($ar[0], SORT_ASC, SORT_STRING,
$ar[1], SORT_NUMERIC, SORT_DESC);
var_dump($ar);
?>
結(jié)果:
array
0 =>
array
0 =>
string
'10' (length=2)
1 =>
int
100
2 =>
int
100
3 =>
int
11
4 =>
string
'a' (length=1)
1 =>
array
0 =>
int
1
1 =>
int
3
2 =>
string
'2' (length=1)
3 =>
int
2
4 =>
int
1
//說(shuō)明:
1 上例中:$ar數(shù)組優(yōu)先按照$ar[0]的字符串值升序排列,如果字符串值相等,再按照$ar[1]數(shù)組的數(shù)字值降序排列。
2 array_multisort函數(shù)的任意一個(gè)位置的參數(shù)如果是數(shù)組,表示排序時(shí)用的值,
如果有多個(gè)數(shù)組參數(shù),優(yōu)先按照前邊的數(shù)組值進(jìn)行排序,如果是常量,例如
SORT_ASC, SORT_DESC, SORT_REGULAR,SORT_NUMERIC, SORT_STRING.
表示排序方法(數(shù)組取值前優(yōu)先)。
==========================================================================================
PHP二維數(shù)組排序函數(shù)
PHP一維數(shù)組的排序可以用sort(),asort(),arsort()等函數(shù),但是PHP二維數(shù)組的排序需要自定義。
以下函數(shù)是對(duì)一個(gè)給定的二維數(shù)組按照指定的鍵值進(jìn)行排序,先看函數(shù)定義:
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)為升序),用法示例:
$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'從低到高的排序。
輸出結(jié)果:(略)。
1 數(shù)組被作為排序函數(shù)的參數(shù),排序以后,數(shù)組本身就發(fā)生了改變,函數(shù)的返回值為bool類型。
2 函數(shù)名中出現(xiàn)單a表示association,含義為,在按值排序的過(guò)程中,保持key=>value的對(duì)應(yīng)關(guān)系不變
3 函數(shù)名中出現(xiàn)單k表示key,含義為,在按值排序的過(guò)程中按照數(shù)組key而不是數(shù)組的值排序
4 函數(shù)名中出現(xiàn)單r的表示reverse,含義為,按照跟不加r的相反的順序排列
5 函數(shù)名中出現(xiàn)單u的表示user-defined,含義為,使用用戶自定義函數(shù)排序,如果函數(shù)的邏輯是參數(shù)1<參數(shù)2返回負(fù)數(shù),則按照升序排列(p1小2返負(fù)升)。
--------------------sort函數(shù)升序排序--------------------------------
復(fù)制代碼 代碼如下:
bool sort ( array &$array [, int $sort_flags= SORT_REGULAR ] )
<?php
$fruits = array("lemon", "orange", "banana", "apple");
sort($fruits);
var_dump($fruits);
?>
結(jié)果:
array
0 =>
string
'apple' (length=5)
1 =>
string
'banana' (length=6)
2 =>
string
'lemon' (length=5)
3 =>
string
'orange' (length=6)
--------------------rsort降序排列--------------------
復(fù)制代碼 代碼如下:
<?php
$fruits = array("lemon", "orange", "banana", "apple");
rsort($fruits);
var_dump($fruits);
?>
結(jié)果:
array
0 =>
string
'orange' (length=6)
1 =>
string
'lemon' (length=5)
2 =>
string
'banana' (length=6)
3 =>
string
'apple' (length=5)
---------------asort按照二維數(shù)組值的升序排列(保持key=>value的關(guān)聯(lián)關(guān)系)-----------
復(fù)制代碼 代碼如下:
<?php
$fruits = array("d" => "lemon", "a" => "orange", "b" => "banana", "c" => "apple");
asort($fruits);
var_dump($fruits);
?>
結(jié)果:
array
'c' =>
string
'apple' (length=5)
'b' =>
string
'banana' (length=6)
'd' =>
string
'lemon' (length=5)
'a' =>
string
'orange' (length=6)
---------arsort按照二維數(shù)組值的降序排列(保持key=>value的關(guān)聯(lián)關(guān)系)---------
復(fù)制代碼 代碼如下:
<?php
$fruits = array("d" => "lemon", "a" => "orange", "b" => "banana", "c" => "apple");
arsort($fruits);
var_dump($fruits);
?>
結(jié)果
array
'a' =>
string
'orange' (length=6)
'd' =>
string
'lemon' (length=5)
'b' =>
string
'banana' (length=6)
'c' =>
string
'apple' (length=5)
--------------------ksort按照數(shù)組的key升序排列--------------
復(fù)制代碼 代碼如下:
<?php
$fruits = array("d"=>"lemon", "a"=>"orange", "b"=>"banana", "c"=>"apple");
ksort($fruits);
var_dump($fruits);
?>
結(jié)果
array
'a' =>
string
'orange' (length=6)
'b' =>
string
'banana' (length=6)
'c' =>
string
'apple' (length=5)
'd' =>
string
'lemon' (length=5)
---------------------krsort按照數(shù)組key的降序排列-----------------------
復(fù)制代碼 代碼如下:
<?php
$fruits = array("d"=>"lemon", "a"=>"orange", "b"=>"banana", "c"=>"apple");
krsort($fruits);
var_dump($fruits);
?>
array
'd' =>
string
'lemon' (length=5)
'c' =>
string
'apple' (length=5)
'b' =>
string
'banana' (length=6)
'a' =>
string
'orange' (length=6)
----------------usort函數(shù)按照用戶自定義的函數(shù)排序----------------
復(fù)制代碼 代碼如下:
<?php
function cmp($a, $b)
{
if ($a == $b) {
return 0;
}
return ($a < $b) ? -1 : 1;
}
$a = array(3, 2, 5, 6, 1);
usort($a, "cmp");
var_dump($a);
?>
結(jié)果:
array
0 =>
int
1
1 =>
int
2
2 =>
int
3
3 =>
int
5
4 =>
int
6
-----------------uksort使用自定義函數(shù)按照數(shù)組的key排序-----------------
復(fù)制代碼 代碼如下:
<?php
function cmp($a, $b)
{
$a = preg_replace('@^(a|an|the) @', '', $a);
$b = preg_replace('@^(a|an|the) @', '', $b);
return strcasecmp($a, $b);
}
$a = array("John" => 1, "the Earth" => 2, "an apple" => 3, "a banana" => 4);
uksort($a, "cmp");
var_dump($a);
?>
結(jié)果:
array
'an apple' =>
int
3
'a banana' =>
int
4
'the Earth' =>
int
2
'John' =>
int
1
--------------uasort將數(shù)組用自定義函數(shù)按照value排序,保持索引關(guān)系不變---------
復(fù)制代碼 代碼如下:
<?php
// Comparison function
function cmp($a, $b) {
if ($a == $b) {
return 0;
}
return ($a < $b) ? -1 : 1;
}
// Array to be sorted
$array = array('a' => 4, 'b' => 8, 'c' => -1, 'd' => -9, 'e' => 2, 'f' => 5, 'g' => 3, 'h' => -4);
var_dump($array);
// Sort and print the resulting array
uasort($array, 'cmp');
var_dump($array);
?>
結(jié)果:
array
'a' =>
int
4
'b' =>
int
8
'c' =>
int
-1
'd' =>
int
-9
'e' =>
int
2
'f' =>
int
5
'g' =>
int
3
'h' =>
int
-4
array
'd' =>
int
-9
'h' =>
int
-4
'c' =>
int
-1
'e' =>
int
2
'g' =>
int
3
'a' =>
int
4
'f' =>
int
5
'b' =>
int
8
-------------------array_multisort排序多個(gè)數(shù)組或多維數(shù)組---------
復(fù)制代碼 代碼如下:
<?php
$ar = array(
array("10", 11, 100, 100, "a"),
array( 1, 2, "2", 3, 1)
);
array_multisort($ar[0], SORT_ASC, SORT_STRING,
$ar[1], SORT_NUMERIC, SORT_DESC);
var_dump($ar);
?>
結(jié)果:
array
0 =>
array
0 =>
string
'10' (length=2)
1 =>
int
100
2 =>
int
100
3 =>
int
11
4 =>
string
'a' (length=1)
1 =>
array
0 =>
int
1
1 =>
int
3
2 =>
string
'2' (length=1)
3 =>
int
2
4 =>
int
1
//說(shuō)明:
1 上例中:$ar數(shù)組優(yōu)先按照$ar[0]的字符串值升序排列,如果字符串值相等,再按照$ar[1]數(shù)組的數(shù)字值降序排列。
2 array_multisort函數(shù)的任意一個(gè)位置的參數(shù)如果是數(shù)組,表示排序時(shí)用的值,
如果有多個(gè)數(shù)組參數(shù),優(yōu)先按照前邊的數(shù)組值進(jìn)行排序,如果是常量,例如
SORT_ASC, SORT_DESC, SORT_REGULAR,SORT_NUMERIC, SORT_STRING.
表示排序方法(數(shù)組取值前優(yōu)先)。
==========================================================================================
PHP二維數(shù)組排序函數(shù)
PHP一維數(shù)組的排序可以用sort(),asort(),arsort()等函數(shù),但是PHP二維數(shù)組的排序需要自定義。
以下函數(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'從低到高的排序。
輸出結(jié)果:(略)。
您可能感興趣的文章:
- php計(jì)算多維數(shù)組中所有值總和的方法
- php計(jì)算數(shù)組相同值出現(xiàn)次數(shù)的代碼(array_count_values)
- php計(jì)算數(shù)組不為空元素個(gè)數(shù)的方法
- php數(shù)組函數(shù)序列之a(chǎn)rray_sum() - 計(jì)算數(shù)組元素值之和
- PHP將二維數(shù)組某一個(gè)字段相同的數(shù)組合并起來(lái)的方法
- php中有關(guān)合并某一字段鍵值相同的數(shù)組合并的改進(jìn)
- php二維數(shù)組合并及去重復(fù)的方法
- php合并數(shù)組中相同元素的方法
- PHP計(jì)算數(shù)組中值的和與乘積的方法(array_sum與array_product函數(shù))
相關(guān)文章
PHP開發(fā)中常見的安全問題詳解和解決方法(如Sql注入、CSRF、Xss、CC等)
這篇文章主要介紹了PHP開發(fā)中常見的安全問題詳解和解決方法,詳細(xì)介紹了例如Sql注入、CSRF、Xss、CC等攻擊手段的背景知識(shí)以及解決方法,需要的朋友可以參考下2014-04-04PHP數(shù)據(jù)庫(kù)操作三:redis用法分析
這篇文章主要介紹了PHP數(shù)據(jù)庫(kù)操作redis用法,結(jié)合實(shí)例形式詳細(xì)分析了php安裝、使用redis的步驟、方法與相關(guān)注意事項(xiàng),需要的朋友可以參考下2017-08-08php eval函數(shù)用法 PHP中eval()函數(shù)小技巧
本函式可將字符串之中的變量值代入,通常用在處理數(shù)據(jù)庫(kù)的數(shù)據(jù)上2012-10-10【CLI】利用Curl下載文件實(shí)時(shí)進(jìn)度條顯示的實(shí)現(xiàn)
這篇文章主要給大家介紹了關(guān)于【CLI】利用Curl下載文件實(shí)時(shí)進(jìn)度條顯示的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。2018-03-03PHP跳出for循環(huán)中的break和continue
在PHP中,可以使用break關(guān)鍵字來(lái)跳出循環(huán),,PHP中還可以使用continue關(guān)鍵字跳過(guò)本次循環(huán)并繼續(xù)執(zhí)行下一次循環(huán),當(dāng)循環(huán)執(zhí)行到continue語(yǔ)句時(shí),本次循環(huán)中continue之后的代碼將不再執(zhí)行,直接進(jìn)入下一次循環(huán)2023-09-09PHP生成可點(diǎn)擊刷新的驗(yàn)證碼簡(jiǎn)單示例
這篇文章主要介紹了PHP生成可點(diǎn)擊刷新的驗(yàn)證碼,結(jié)合簡(jiǎn)單實(shí)例形式分析了php驗(yàn)證碼的實(shí)現(xiàn)與調(diào)用顯示方法,涉及js動(dòng)態(tài)調(diào)用驗(yàn)證碼php文件的相關(guān)技巧,需要的朋友可以參考下2016-05-05