downloads | documentation | faq | getting help | mailing lists | licenses | wiki | reporting bugs | php.net sites | links | conferences | my php.net

search for in the

strncasecmp> <strnatcasecmp
Last updated: Fri, 24 Jul 2009

view this page in

strnatcmp

(PHP 4, PHP 5)

strnatcmp"자연순" 알고리즘을 이용한 문자열 비교

설명

int strnatcmp ( string $str1 , string $str2 )

사람이 하는 것과 동일한 방법인 "자연순"으로 알파벳/숫자 문자열의 비교 알고리즘을 수행합니다. 이 비교는 대소문자를 구분합니다.

인수

str1

첫번째 문자열.

str2

두번째 문자열.

반환값

다른 문자열 비교 함수와 마찬가지로, str1str2 보다 작으면 < 0을, str1str2 보다 크면 > 0을, 같으면 0을 반환합니다.

예제

아래 예제는 이 알고리즘과 일반적인 컴퓨터 정렬 알고리즘(strcmp()에서 사용)의 차이점입니다:

<?php
$arr1 
$arr2 = array("img12.png""img10.png""img2.png""img1.png");
echo 
"표준 문자열 비교\n";
usort($arr1"strcmp");
print_r($arr1);
echo 
"\n자연순 문자열 비교\n";
usort($arr2"strnatcmp");
print_r($arr2);
?>

위 예제의 출력:

표준 문자열 비교
Array
(
    [0] => img1.png
    [1] => img10.png
    [2] => img12.png
    [3] => img2.png
)

자연순 문자열 비교
Array
(
    [0] => img1.png
    [1] => img2.png
    [2] => img10.png
    [3] => img12.png
)

자세한 정보는 Martin Pool의 » 자연순 문자열 비교 페이지를 참고하십시오.

참고

  • preg_match() - 정규표현식 매치를 수행
  • strcasecmp() - 대소문자 구분 없는 바이너리 안전 문자열 비교
  • substr() - Return part of a string
  • stristr() - 대소문자를 구분하지 않는 strstr
  • strcmp() - 바이너리 안전 문자열 비교
  • strncmp() - 처음 n 문자의 바이너리 안전 문자열 비교
  • strncasecmp() - 대소문자 구분 없는 처음 n 문자의 바이너리 안전 문자열 비교
  • strnatcasecmp() - "자연순" 알고리즘을 이용한 대소문자 구분 없는 문자열 비교
  • strstr() - 문자열이 처음으로 나오는 부분을 찾습니다
  • natsort() - "자연순" 알고리즘으로 배열 정렬
  • natcasesort() - "자연순" 알고리즘으로 대소문자를 구분하지 않고 배열 정렬



add a note add a note User Contributed Notes
strnatcmp
thomas at uninet dot se
25-Jul-2006 07:50
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.

strncasecmp> <strnatcasecmp
Last updated: Fri, 24 Jul 2009
 
 
show source | credits | stats | sitemap | contact | advertising | mirror sites