Heim >Backend-Entwicklung >PHP-Tutorial >字符串的自然排序有关问题

字符串的自然排序有关问题

WBOY
WBOYOriginal
2016-06-13 09:59:06962Durchsuche

字符串的自然排序问题
1、
$a = 'x2-g8';
$b = 'x2-y7';
echo strnatcasecmp($a, $b); //输出-1
---------------------------------------------
2、
$a = 'a10a';
$b = 'a010';
echo strnatcasecmp($a, $b); //输出1
---------------------------------------------
3、
$a = '10a';
$b = '10.0a';
echo strnatcasecmp($a, $b); //输出1
---------------------------------------------

问题:
1、手册中写的是:
Strings can contain several number parts: x2-g8 in which case numeric fields are separated by nonnumeric characters. Leading spaces are ignored.
这意思不就是说可以忽略前导位置吗?那$a和$b不就是28,27吗?
2、$a和$b不都是10吗?为什么会被认为不同呢?
3、我还是认为$a和$b都是10啊~

看了一遍手册中的“字符串自然排序”规则,但是没太看懂,能帮我讲一下字符串自然排序的规则有哪些吗?
另外字符串自然排序和数组用的自然排序(natcasesort())是一个规则吗?

谢谢!

------解决方案--------------------
没用过!你可以用数组排序,那就是自然排序!

一般是根据拉字字母排序! 

中文,可以转成gbk然后排序。转成相应的语言码后, 应可以直接比较大小。
大小写字母是不同的。


------解决方案--------------------

#1.字符串首位为0将被忽略,所以你看下面两个例子是不同的的结果

echo strnatcasecmp('7','08'); //-1
echo strnatcasecmp('y7','y08'); //1

#2.字符串内的空格将被忽略

#3.如果是非数字对上数字,或者非数字对非数字,则以ascii码为准,如果是数字对数字,有两种情况
a).任意一方数字串以0开头被视为小的一方,比如
echo strnatcasecmp('y721','y07203'); //1,因为y=y,7 > 0
b).如果都非0,则数字小的一方为小的一方,比如
echo strnatcasecmp('y723','y70212'); //1,因为y=y,70212 > 723

可以阅读源代码,这部分很容易看懂。
------解决方案--------------------
echo strnatcasecmp('7','08'); //-1
echo strnatcasecmp('y7','y08'); //1

-11

$a = 'x2-g8';
$b = 'x2-y7';
echo strnatcasecmp($a, $b); //输出-1
---------------------------------------------
2、
$a = 'a10a';
$b = 'a010';
echo strnatcasecmp($a, $b); //输出1
---------------------------------------------
3、
$a = '10a';
$b = '10.0a';
echo strnatcasecmp($a, $b); //输出1

-111


有什么不对的吗?
字符串比较时时按字节比较,直至对应位不等时,比较相应两字符

如果说明文字与此解释不符,请注意一个事实:老外不是上帝
如果只是理解上的差异,请去打你英语老师的屁股

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn