If you want to compare $_SESSION variables to a string use this
<?php
if(isset($_SESSION['usertype']))
{
echo "usertype " .$_SESSION['usertype'];
$ut = $_SESSION['usertype'];
if(strnatcmp($ut,"admin"))
{
echo "hello admin";
}
}
?>
strnatcmp
(PHP 4, PHP 5)
strnatcmp — "自然順"アルゴリズムにより文字列比較を行う
説明
int strnatcmp
( string
$str1
, string $str2
)この関数は、人間が行うような手法でアルファベットまたは数字の 文字列の順序を比較するアルゴリズムを実装します。この手法は、"自然順" と言われます。 この比較は、大文字小文字を区別することに注意してください。
パラメータ
-
str1 -
最初の文字列。
-
str2 -
次の文字列。
返り値
他の文字列比較関数と同様に、この関数は、
str1 が str2
より小さいに場合に < 0、str1 が
str2 より大きい場合に > 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
)
参考
- preg_match() - 正規表現によるマッチングを行う
- strcasecmp() - 大文字小文字を区別しないバイナリセーフな文字列比較を行う
- substr() - 文字列の一部分を返す
- stristr() - 大文字小文字を区別しない strstr
- strcmp() - バイナリセーフな文字列比較
- strncmp() - 最初の n 文字についてバイナリセーフな文字列比較を行う
- strncasecmp() - バイナリセーフで大文字小文字を区別しない文字列比較を、最初の n 文字について行う
- strnatcasecmp() - "自然順"アルゴリズムにより大文字小文字を区別しない文字列比較を行う
- strstr() - 文字列が最初に現れる位置を見つける
- natsort() - "自然順"アルゴリズムで配列をソートする
- natcasesort() - 大文字小文字を区別しない"自然順"アルゴリズムを用いて配列をソートする
Zero ¶
2 years ago
thomas at uninet dot se ¶
6 years ago
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.
