PHP數(shù)組排序函數(shù)合集_PHP教程
推薦:最完整的PHP.INI中文詳細(xì)配置指南下面是詳細(xì)的PHP.INI配置指南,中英文對(duì)照并有詳細(xì)說(shuō)明,篇幅較長(zhǎng),如果您需要查找某項(xiàng)設(shè)置參數(shù),建議使用CTRL+F進(jìn)行查詢(xún). ;;;;;;;;;;;;;;;;; ;; 關(guān)于php.ini ;; ;;;;;;;;;;;;;;;;; ; 這個(gè)文件必須命名為php.ini并放置在httpd.conf中PHPINIDir指令指定的目錄中。 ; 最新版
下邊提到的幾個(gè)PHP數(shù)組排序函數(shù)的排序有一些共性:
1 數(shù)組被作為排序函數(shù)的參數(shù),排序以后,數(shù)組本身就發(fā)生了改變,函數(shù)的返回值為bool類(lèi)型。
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,含義為,使用用戶(hù)自定義函數(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);
?>
結(jié)果
array
'd' => string 'lemon' (length=5)
'c' => string 'apple' (length=5)
'b' => string 'banana' (length=6)
'a' => string 'orange' (length=6)----------------usort函數(shù)按照用戶(hù)自定義的函數(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計(jì)算未知長(zhǎng)度的字符串哪個(gè)字符出現(xiàn)的次數(shù)最多用到的函數(shù): str_split:把字符串分割到數(shù)組中。類(lèi)似的函數(shù)explode() 函數(shù)把字符串分割為數(shù)組。 array_count_values:用于統(tǒng)計(jì)數(shù)組中所有值出現(xiàn)的次數(shù)。 arsort:對(duì)數(shù)組進(jìn)行逆向排序并保持索引關(guān)系。主要用于對(duì)那些單元順序很重要的結(jié)合數(shù)組進(jìn)行排序。 $str = asdfgfdas32
- PHPNOW安裝Memcached擴(kuò)展方法詳解
- php記錄頁(yè)面代碼執(zhí)行時(shí)間
- PHP中獎(jiǎng)概率的抽獎(jiǎng)算法程序代碼
- apache設(shè)置靜態(tài)文件緩存方法介紹
- php對(duì)圖像的各種處理函數(shù)代碼小結(jié)
- PHP 關(guān)于訪(fǎng)問(wèn)控制的和運(yùn)算符優(yōu)先級(jí)介紹
- 關(guān)于PHP語(yǔ)言構(gòu)造器介紹
- php/js獲取客戶(hù)端mac地址的實(shí)現(xiàn)代碼
- php5.5新數(shù)組函數(shù)array_column使用
- PHP preg_match的匹配多國(guó)語(yǔ)言的技巧
- php 中序列化和json使用介紹
- php采集文章中的圖片獲取替換到本地
- 相關(guān)鏈接:
- 教程說(shuō)明:
PHP教程-PHP數(shù)組排序函數(shù)合集
。