(PHP 5 >= 5.2.0, PHP 7, PHP 8)
ArrayObject::natcasesort — Trie un tableau en utilisant le tri naturel sans la casse
Cette méthode est la version insensible à la casse de ArrayObject::natsort.
Cette méthode implémente un algorithme de tri qui ordonne les chaînes alpha-numérique de la même façon qu'un humain le ferait. Ceci est décrit comme un tri naturel.
Note:
Si deux membres se comparent comme égaux, ils maintiennent leur ordre original. Antérieur à PHP 8.0.0, leur ordre relatif dans le tableau trié n'est pas défini.
Cette fonction ne contient aucun paramètre.
Aucune valeur n'est retournée.
| Version | Description |
|---|---|
| 8.2.0 |
Le type de retour est maintenant true, auparavant il était bool.
|
Exemple #1 Exemple avec ArrayObject::natcasesort()
<?php
$array = array('IMG0.png', 'img12.png', 'img10.png', 'img2.png', 'img1.png', 'IMG3.png');
$arr1 = new ArrayObject($array);
$arr2 = clone $arr1;
$arr1->asort();
echo "Tri standard\n";
var_dump($arr1);
$arr2->natcasesort();
echo "\nTri naturel\n";
var_dump($arr2);
?>L'exemple ci-dessus va afficher :
Tri standard
object(ArrayObject)#1 (1) {
["storage":"ArrayObject":private]=>
array(6) {
[0]=>
string(8) "IMG0.png"
[5]=>
string(8) "IMG3.png"
[4]=>
string(8) "img1.png"
[2]=>
string(9) "img10.png"
[1]=>
string(9) "img12.png"
[3]=>
string(8) "img2.png"
}
}
Tri naturel
object(ArrayObject)#2 (1) {
["storage":"ArrayObject":private]=>
array(6) {
[0]=>
string(8) "IMG0.png"
[4]=>
string(8) "img1.png"
[3]=>
string(8) "img2.png"
[5]=>
string(8) "IMG3.png"
[2]=>
string(9) "img10.png"
[1]=>
string(9) "img12.png"
}
}
Pour plus d'information, voir la page la » comparaison de chaînes en ordre naturel de Martin Pool.