這篇文章主要介紹“PHP數(shù)組排序函數(shù)總結(jié)”,在日常操作中,相信很多人在PHP數(shù)組排序函數(shù)總結(jié)問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”PHP數(shù)組排序函數(shù)總結(jié)”的疑惑有所幫助!接下來,請跟著小編一起來學(xué)習(xí)吧!
為邢臺縣等地區(qū)用戶提供了全套網(wǎng)頁設(shè)計制作服務(wù),及邢臺縣網(wǎng)站建設(shè)行業(yè)解決方案。主營業(yè)務(wù)為成都網(wǎng)站設(shè)計、成都做網(wǎng)站、邢臺縣網(wǎng)站設(shè)計,以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務(wù)。我們深信只要達(dá)到每一位用戶的要求,就會得到認(rèn)可,從而選擇與我們長期合作。這樣,我們也可以走得更遠(yuǎn)!下邊提到的幾個數(shù)組函數(shù)的排序有一些共性:
1 數(shù)組被作為排序函數(shù)的參數(shù),排序以后,數(shù)組本身就發(fā)生了改變,函數(shù)的返回值為bool類型。
2 函數(shù)名中出現(xiàn)單a表示association,含義為,在按值排序的過程中,保持key=>value的對應(yīng)關(guān)系不變
3 函數(shù)名中出現(xiàn)單k表示key,含義為,在按值排序的過程中按照數(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排序多個數(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
//說明:
1 上例中:$ar數(shù)組優(yōu)先按照$ar[0]的字符串值升序排列,如果字符串值相等,再按照$ar[1]數(shù)組的數(shù)字值降序排列。
2 array_multisort函數(shù)的任意一個位置的參數(shù)如果是數(shù)組,表示排序時用的值,
如果有多個數(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ù)是對一個給定的二維數(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;
}
它可以對二維數(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);
上面是對$array這個二維數(shù)組按照'price'從低到高的排序。
輸出結(jié)果:(略)。
到此,關(guān)于“PHP數(shù)組排序函數(shù)總結(jié)”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識,請繼續(xù)關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬嵱玫奈恼拢?/p>
本文題目:PHP數(shù)組排序函數(shù)總結(jié)-創(chuàng)新互聯(lián)
標(biāo)題URL:http://www.rwnh.cn/article14/copode.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供全網(wǎng)營銷推廣、響應(yīng)式網(wǎng)站、自適應(yīng)網(wǎng)站、搜索引擎優(yōu)化、用戶體驗、網(wǎng)站營銷
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)