對陣列進行排序
php 中的陣列有幾種排序函式:
分類()
按值按升序對陣列進行排序。
$fruits = ['Zitrone', 'Orange', 'Banane', 'Apfel'];
sort($fruits);
print_r($fruits);
結果是
Array
(
[0] => Apfel
[1] => Banane
[2] => Orange
[3] => Zitrone
)
rsort()
按值按降序對陣列進行排序。
$fruits = ['Zitrone', 'Orange', 'Banane', 'Apfel'];
rsort($fruits);
print_r($fruits);
結果是
Array
(
[0] => Zitrone
[1] => Orange
[2] => Banane
[3] => Apfel
)
ASORT()
按值按升序對陣列進行排序並保留 indecies。
$fruits = [1 => 'lemon', 2 => 'orange', 3 => 'banana', 4 => 'apple'];
asort($fruits);
print_r($fruits);
結果是
Array
(
[4] => apple
[3] => banana
[1] => lemon
[2] => orange
)
arsort()
按值按降序對陣列進行排序並保留 indecies。
$fruits = [1 => 'lemon', 2 => 'orange', 3 => 'banana', 4 => 'apple'];
arsort($fruits);
print_r($fruits);
結果是
Array
(
[2] => orange
[1] => lemon
[3] => banana
[4] => apple
)
ksort()
按鍵按升序對陣列進行排序
$fruits = ['d'=>'lemon', 'a'=>'orange', 'b'=>'banana', 'c'=>'apple'];
ksort($fruits);
print_r($fruits);
結果是
Array
(
[a] => orange
[b] => banana
[c] => apple
[d] => lemon
)
krsort()
按鍵降序對陣列進行排序。
$fruits = ['d'=>'lemon', 'a'=>'orange', 'b'=>'banana', 'c'=>'apple'];
krsort($fruits);
print_r($fruits);
結果是
Array
(
[d] => lemon
[c] => apple
[b] => banana
[a] => orange
)
natsort()
以人類將要做的方式(自然順序)對陣列進行排序。
$files = ['File8.stack', 'file77.stack', 'file7.stack', 'file13.stack', 'File2.stack'];
natsort($files);
print_r($files);
結果是
Array
(
[4] => File2.stack
[0] => File8.stack
[2] => file7.stack
[3] => file13.stack
[1] => file77.stack
)
natcasesort()
以人類將要做的方式(自然順序)對陣列進行排序,但是大小寫
$files = ['File8.stack', 'file77.stack', 'file7.stack', 'file13.stack', 'File2.stack'];
natcasesort($files);
print_r($files);
結果是
Array
(
[4] => File2.stack
[2] => file7.stack
[0] => File8.stack
[3] => file13.stack
[1] => file77.stack
)
洗牌()
隨機播放一個陣列(隨機排序)。
$array = ['aa', 'bb', 'cc'];
shuffle($array);
print_r($array);
如在描述中所寫,它是隨機的,因此這裡只是它可以產生的一個例子
Array
(
[0] => cc
[1] => bb
[2] => aa
)
usort()
使用使用者定義的比較函式對陣列進行排序。
function compare($a, $b)
{
if ($a == $b) {
return 0;
}
return ($a < $b) ? -1 : 1;
}
$array = [3, 2, 5, 6, 1];
usort($array, 'compare');
print_r($array);
結果是
Array
(
[0] => 1
[1] => 2
[2] => 3
[3] => 5
[4] => 6
)
uasort()
使用使用者定義的比較函式對陣列進行排序並保留鍵。
function compare($a, $b)
{
if ($a == $b) {
return 0;
}
return ($a < $b) ? -1 : 1;
}
$array = ['a' => 1, 'b' => -3, 'c' => 5, 'd' => 3, 'e' => -5];
uasort($array, 'compare');
print_r($array);
結果是
Array
(
[e] => -5
[b] => -3
[a] => 1
[d] => 3
[c] => 5
)
uksort()
使用使用者定義的比較函式按鍵對陣列進行排序。
function compare($a, $b)
{
if ($a == $b) {
return 0;
}
return ($a < $b) ? -1 : 1;
}
$array = ['ee' => 1, 'g' => -3, '4' => 5, 'k' => 3, 'oo' => -5];
uksort($array, 'compare');
print_r($array);
結果是
Array
(
[ee] => 1
[g] => -3
[k] => 3
[oo] => -5
[4] => 5
)