對陣列進行排序
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
)