The function treats '_' as after letters and numbers when it would be placed before logically.
(PHP 4, PHP 5, PHP 7, PHP 8)
strnatcasecmp — Comparaison de chaînes avec l'algorithme d'"ordre naturel" (insensible à la casse)
strnatcasecmp() implémente l'algorithme de comparaison
qui ordonne les chaînes tel qu'un homme le ferait. Cette fonction est
similaire à la fonction strnatcmp(), mais la comparaison
n'est pas sensible à la casse. Pour plus de détails, reportez-vous à
» Natural Order String
Comparison
de Martin Pool (en anglais).
string1
La première chaîne.
string2
La seconde chaîne.
Tout comme les autres fonctions de comparaison de chaînes,
celle-ci retourne -1
si string1
est inférieure à string2
; 1
si
string1
est supérieure à
string2
, et 0
si les deux chaînes sont égales.
Version | Description |
---|---|
8.2.0 |
Cette fonction retourne désormais -1 ou 1 ,
alors qu'auparavant elle renvoyait un nombre négatif ou positif.
|
Exemple #1 Exemple avec strnatcasecmp()
<?php
var_dump(strnatcasecmp('Apple', 'Banana'));
var_dump(strnatcasecmp('Banana', 'Apple'));
var_dump(strnatcasecmp('apple', 'Apple'));
?>
L'exemple ci-dessus va afficher :
int(-1) int(1) int(0)
The function treats '_' as after letters and numbers when it would be placed before logically.
Use strnatcmp to avoid the _ problem as mentioned below;
<< The function treats '_' as after letters and numbers when it would be placed before logically. >>
There seems to be a bug in the localization for strnatcmp and strnatcasecmp. I searched the reported bugs and found a few entries which were up to four years old (but the problem still exists when using swedish characters).
These functions might work instead.
<?php
function _strnatcasecmp($left, $right) {
return _strnatcmp(strtolower($left), strtolower($right));
}
function _strnatcmp($left, $right) {
while((strlen($left) > 0) && (strlen($right) > 0)) {
if(preg_match('/^([^0-9]*)([0-9].*)$/Us', $left, $lMatch)) {
$lTest = $lMatch[1];
$left = $lMatch[2];
} else {
$lTest = $left;
$left = '';
}
if(preg_match('/^([^0-9]*)([0-9].*)$/Us', $right, $rMatch)) {
$rTest = $rMatch[1];
$right = $rMatch[2];
} else {
$rTest = $right;
$right = '';
}
$test = strcmp($lTest, $rTest);
if($test != 0) {
return $test;
}
if(preg_match('/^([0-9]+)([^0-9].*)?$/Us', $left, $lMatch)) {
$lTest = intval($lMatch[1]);
$left = $lMatch[2];
} else {
$lTest = 0;
}
if(preg_match('/^([0-9]+)([^0-9].*)?$/Us', $right, $rMatch)) {
$rTest = intval($rMatch[1]);
$right = $rMatch[2];
} else {
$rTest = 0;
}
$test = $lTest - $rTest;
if($test != 0) {
return $test;
}
}
return strcmp($left, $right);
}
?>
The code is not optimized. It was just made to solve my problem.