strnatcmp

(PHP 4, PHP 5)

strnatcmpСравнение строк с использованием алгоритма "natural order"

Описание

int strnatcmp ( string $str1 , string $str2 )

Эта функция реализует алгоритм сравнения, упорядочивающий алфавитно-цифровые строки подобно тому, как это сделал бы человек, такой алгоритм называется "natural ordering". Сравнение происходит с учетом регистра.

Список параметров

str1

Первая строка.

str2

Вторая строка.

Возвращаемые значения

Подобно другим функциям сравнения строк, данная функция возвращает отрицательное число, если str1 меньше, чем str2, положительное число, если str1 больше, чем str2, и 0 если строки равны.

Примеры

Пример, показывающий отличие этого алгоритма от обычных функций сравнения (используемых в strcmp()), приведен ниже:

<?php
$arr1 
$arr2 = array("img12.png""img10.png""img2.png""img1.png");
echo 
"Стандартный алгоритм сравнения\n";
usort($arr1"strcmp");
print_r($arr1);
echo 
"\nАлгоритм \"natural order\"\n";
usort($arr2"strnatcmp");
print_r($arr2);
?>

Результат выполнения данного примера:

Стандартный алгоритм сравнения
Array
(
    [0] => img1.png
    [1] => img10.png
    [2] => img12.png
    [3] => img2.png
)

Алгоритм "natural order"
Array
(
    [0] => img1.png
    [1] => img2.png
    [2] => img10.png
    [3] => img12.png
)
Для получения дополнительной информации см. » Natural Order String Comparison

Смотрите также

  • preg_match() - Выполняет проверку на соответствие регулярному выражению
  • strcasecmp() - Бинарно-безопасное сравнение строк без учета регистра
  • substr() - Возвращает подстроку
  • stristr() - Регистро-независимый вариант функции strstr
  • strcmp() - Бинарно-безопасное сравнение строк
  • strncmp() - Бинарно-безопасное сравнение первых n символов строк
  • strncasecmp() - Бинарно-безопасное сравнение первых n символов строк без учета регистра
  • strnatcasecmp() - Сравнение строк без учета регистра с использованием алгоритма "natural order"
  • strstr() - Находит первое вхождение подстроки
  • natsort() - Сортирует массив, используя алгоритм "natural order"
  • natcasesort() - Сортирует массив, используя алгоритм "natural order" без учета регистра символов

Коментарии

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.
2006-07-25 03:50:13
http://php5.kiev.ua/manual/ru/function.strnatcmp.html
Can also be used with combination of a compare for an array nested value, like

<?php
$array 
= array(
   
"city" => "xyz",
   
"names" => array(
        array(
           
"name" => "Ana2",
           
"id" => 1
       
) ,
        array(
           
"name" => "Ana1",
           
"id" => 2
       
)
    )
);
usort($array["names"], function ($a$b)    {    return strnatcmp($a['name'], $b['name']);} );
2016-12-12 17:34:16
http://php5.kiev.ua/manual/ru/function.strnatcmp.html
This function has some interesting behaviour on strings consisting of mixed numbers and letters.

One may expect that such a mixed string would be treated as alpha-numeric, but that is not true.

var_dump(strnatcmp('23','123')); →
int(-1)
As expected, 23<123   (even though first digit is higher, overall number is smaller)

var_dump(strnatcmp('yz','xyz')); →
int(1)
As expected, yz>xyz   (string comparison, irregardless of string length)

var_dump(strnatcmp('2x','12y')); →
int(-1)
Remarkable, 2x<12y    (does a numeric comparison)

var_dump(strnatcmp('20x','12y'));
int(1)
Remarkable, 20x>12y    (does a numeric comparison)

It seems to be splitting what is being compared into runs of numbers and letters, and then comparing each run in isolation, until it has an ordering difference.
2017-05-04 04:16:46
http://php5.kiev.ua/manual/ru/function.strnatcmp.html
Some more remarkable outcomes:

var_dump(strnatcmp("0.15m", "0.2m"));
int(1)

var_dump(strnatcmp("0.15m", "0.20m"));
int(-1)

It's not about localisation:

var_dump(strnatcmp("0,15m", "0,2m"));
int(1)

var_dump(strnatcmp("0,15m", "0,20m"));
int(-1)
2018-10-30 18:24:30
http://php5.kiev.ua/manual/ru/function.strnatcmp.html

    Поддержать сайт на родительском проекте КГБ