Sortowanie tablic

PHP oferuje kilka funkcji sortujących tablice, a ten dokument został stworzony aby pomóc je uporządkować.

Główne różnice między funkcjami sortującymi są następujące:

  • Niektóre sortują po kluczu tablicy, a inne po jej wartości: $array['klucz'] = 'wartość';
  • Czy przypisanie klucza do wartości zostaje zachowane, czy też klucze są resetowane i tablice otrzymują indeksy numeryczne (0,1,2...)
  • Kolejność sortowania: alfabetyczna, rosnąca, malejąca, numeryczna, naturalna, losowa lub określona przez użytkownika
  • Uwaga: wszystkie z funkcji sortujących operują bezpośrednio na zmiennej zawierającej tablicę zamiast zwracać nową posortowaną tablicę.
  • Jeżeli którakolwiek z tych funkcji określa dwa elementy jako równoznaczne, oznacza to że kolejność nie została zdefiniowana (sortowanie nie działa poprawnie).

Właściwości funkcji sortujących
Nazwa funkcji Sortuje po Zachowuje przypisanie kluczy Kolejność sortowania Powiązane funkcje
array_multisort() wartości asocjacyjne tak, numeryczne nie pierwsza tablica lub opcje sortowania array_walk()
asort() wartości tak rosnąco arsort()
arsort() wartości tak malejąco asort()
krsort() kluczu tak malejąco ksort()
ksort() kluczu tak rosnąco asort()
natcasesort() wartości tak naturalnie, bez uwzg. wielkości znaków natsort()
natsort() wartości tak naturalnie natcasesort()
rsort() wartości nie malejąco sort()
shuffle() wartości nie losowo array_rand()
sort() wartości nie rosnąco rsort()
uasort() wartości tak zdefiniowana przez użytkownika uksort()
uksort() kluczu tak zdefiniowana przez użytkownika uasort()
usort() wartości nie zdefiniowana przez użytkownika uasort()

add a note add a note

User Contributed Notes 3 notes

up
129
"Matthew Rice"
10 years ago
While this may seem obvious, user-defined array sorting functions ( uksort(), uasort(), usort() ) will *not* be called if the array does not have *at least two values in it*.

The following code:                       

<?php

function usortTest($a, $b) {
   
var_dump($a);
   
var_dump($b);
    return -
1;
}

$test = array('val1');
usort($test, "usortTest");

$test2 = array('val2', 'val3');
usort($test2, "usortTest");

?>

Will output:

string(4) "val3"
string(4) "val2"

The first array doesn't get sent to the function.

Please, under no circumstance, place any logic that modifies values, or applies non-sorting business logic in these functions as they will not always be executed.
up
24
oculiz at gmail dot com
13 years ago
Another way to do a case case-insensitive sort by key would simply be:

<?php
uksort
($array, 'strcasecmp');
?>

Since strcasecmp is already predefined in php it saves you the trouble to actually write the comparison function yourself.
up
-26
Hayley Watson
7 years ago
Stabilizing the sort functions (in this case, usort).

<?php
function stable_usort(&$array, $cmp)
{
   
$i = 0;
   
$array = array_map(function($elt)use(&$i)
    {
        return [
$i++, $elt];
    },
$array);
   
usort($array, function($a, $b)use($cmp)
    {
        return
$cmp($a[1], $b[1]) ?: ($a[0] - $b[0]);
    });
   
$array = array_column($array, 1);
}
?>

Tags each array element with its original position in the array so that when the comparison function returns 0 the tie can be broken to put the earlier element first.
To Top