Python 2如何比较 string 和 int?为什么列表比数字大,元组比列表大?

下面的代码片段用输出(就像在 ideone.com 上看到的那样)进行了注释:

print "100" < "2"      # True
print "5" > "9"        # False


print "100" < 2        # False
print 100 < "2"        # True


print 5 > "9"          # False
print "5" > 9          # True


print [] > float('inf') # True
print () > []          # True

有人能解释一下为什么输出是这样的吗?


实施细节

  • 这种行为是由语言规范强制的,还是由实现者决定的?
  • 任何主要的 Python 实现之间是否存在差异?
  • Python 语言的不同版本之间是否存在差异?
86006 次浏览

字符串 按照字典法比较,不同的类型按照它们的类型名称进行比较("int" < "string")。3.x 修正了第二点,使它们不具有可比性。

来自 巨蟒2手册:

CPython 实现细节: 除了数字以外,不同类型的对象按照它们的类型名称排序; 不支持正确比较的相同类型的对象按照它们的地址排序。

当您订购两个字符串或两个数字类型时,排序是按照预期的方式进行的(字符串的字典排序,整数的数字排序)。

当您订购数值类型和非数值类型时,数值类型优先。

>>> 5 < 'foo'
True
>>> 5 < (1, 2)
True
>>> 5 < {}
True
>>> 5 < [1, 2]
True

当你排序两个不兼容的类型时,如果两个类型都不是数字类型,那么它们就是按照类型名的字母顺序排序的:

>>> [1, 2] > 'foo'   # 'list' < 'str'
False
>>> (1, 2) > 'foo'   # 'tuple' > 'str'
True


>>> class Foo(object): pass
>>> class Bar(object): pass
>>> Bar() < Foo()
True

一个例外是总是出现在新样式类之前的旧样式类。

>>> class Foo: pass           # old-style
>>> class Bar(object): pass   # new-style
>>> Bar() < Foo()
False

这种行为是由语言规范强制的,还是由实现者决定的?

没有语言规范语言参考说:

否则,不同类型的对象总是比较不相等,排序一致但任意。

所以它是一个实现细节。

任何主要的 Python 实现之间是否存在差异?

我不能回答这个问题,因为我只使用了正式的 CPython 实现,但是还有其他 Python 实现,比如 PyPy。

Python 语言的不同版本之间是否存在差异?

在 Python 3.x 中,行为已经改变,因此尝试排序一个整数和一个字符串将会产生一个错误:

>>> '10' > 5
Traceback (most recent call last):
File "<pyshell#0>", line 1, in <module>
'10' > 5
TypeError: unorderable types: str() > int()