International PHP Conference 2019 - Spring Edition

Tri des tableaux

PHP dispose de nombreuses fonctions pour trier les tableaux, et cette section du manuel va vous aider à vous y retrouver.

Les différences principales sont :

  • Certains des tris de tableau sont basés sur les clés, tandis que les autres sont basés sur les valeurs : $array['cle'] = 'valeur';
  • Certains tris maintiennent la corrélation entre les clés et les valeurs, et d'autres non, ce qui signifie que les clés sont généralement réaffectées numériquement (0,1,2 ...)
  • L'ordre du tri peut être : alphabétique, croissant, décroissant, numérique, naturel, aléatoire ou personnalisé.
  • Note : toutes ces fonctions de tris travaillent sur le tableau lui-même, contrairement à la pratique normale qui serait de retourner le tableau trié.
  • Si une de ces fonctions de tri évalue 2 membres comme égaux, alors l'ordre est indéfini (le tri n'est pas stable).

Attributs de fonctions de tri
Nom de la fonction Tri par Association clé-valeur Ordre de tri Fonctions associée
array_multisort() valeur associatif oui, numérique non premier tableau, ou bien options de tri array_walk()
asort() valeur oui croissant arsort()
arsort() valeur oui décroissant asort()
krsort() clé oui décroissant ksort()
ksort() clé oui croissant asort()
natcasesort() valeur oui naturel, insensible à la casse natsort()
natsort() valeur oui naturel natcasesort()
rsort() valeur non décroissant sort()
shuffle() valeur non aléatoire array_rand()
sort() valeur non croissant rsort()
uasort() valeur oui Défini par une fonction utilisateur uksort()
uksort() clé oui Défini par une fonction utilisateur uasort()
usort() valeur non Défini par une fonction utilisateur uasort()

add a note add a note

User Contributed Notes 7 notes

"Matthew Rice"
5 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:                       


function usortTest($a, $b) {
    return -

$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.
oculiz at gmail dot com
7 years ago
Another way to do a case case-insensitive sort by key would simply be:

($array, 'strcasecmp');

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

function stable_usort(&$array, $cmp)
$i = 0;
$array = array_map(function($elt)use(&$i)
        return [
$i++, $elt];
usort($array, function($a, $b)use($cmp)
$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.
luca at lauretta dot info
1 month ago
If you're looking for a quick solution to make usort stable, you could use uksort like in the following example:


($array, function ($ak, $bk) use ($array) {
$a = $array[$ak];
$b = $array[$bk];
    if (
$a['foo'] === $b['foo']) return $ak - $bk;
$a['foo'] > $b['foo'] ? 1 : -1;


This works as expected only if the initial indices (keys) of $array are in ascending order.
bizarrus at icloud dot com
3 months ago
If you wan't to sort JSON based data or an multidimensional object (ascending or descending), you must fetch the array/object keys for sorting - After a sort, you can build a new Object with the correct sorting.

**Example Data:**
= [
'nameZ' => [
'A' => true,
'F'    => true,
'K'    => true
'nameU' => 'Hello World!',
'nameA' => [
'subData' => [
'resultX' => 1,
'resultB' => 4,
'resultI' => 6
'nameK' => [
'testing' => true

function json_sort(&$json, $ascending = true) {
$names = [];
// Creating a named array for sorting
foreach($json AS $name => $value) {
$names[] = $name;
$ascending) {
        } else {
$result = [];
$names AS $index => $name) {
// Sorting Sub-Data
if(is_array($json[$name]) || is_object($json[$name])) {
json_sort($json[$name], $ascending);
$result[$name] = $json[$name];
$json = $result;

($json, true); // Ascending order


($json, false); // Descending order

I had written these method for generating HashValues for an API-Request. The HTTP-Request POST the JSON-Data as Body and over GET-Parameter, an digest/token will be appended to validate the JSON-Data (prevent manipulation of the JSON Data).
monicse09ku at yahoo dot com
3 years ago
// takes an array and desired key value and returns an array
// searches through an array for a given key, if found the key that row is made the first row and the other rows are inserted accordingly.
// the facility of this function is to get the value with a specific key of an array as the first value.

/////////////////////////////// function starts //////////////////////////////

function dksort($array, $case){
        $a[$case] = $array[$case];
        foreach($array as $key=>$val){

                $a[$key] = $array[$key];

    return $a;

$d = array(

$c = dksort($d, '55');

////////////////////////// function ends ////////////////////////////////////////
3 years ago
simple example sorting dotted version numbers

     function sortByVersionnumber($a,$b){
         $ta=explode(".",$a); $tb=explode(".",$b);
         foreach ($ta as $k => $v){
             if (isset($tb[$k])){
                 if($ta[$k] > $tb[$k]) {
                     return 1;
                 } elseif($ta[$k] < $tb[$k]) {
                     return -1;
         return 0;
     function vnksort(&$array){
         uksort($array ,"sortByVersionnumber");
To Top