44

In Python 2.x:

>>> '' > 0
True

Why is that?

2
  • 23
    BTW, Python 3.0 produces a TypeError: unorderable types: str() > int() for the same comparison Commented Mar 5, 2010 at 2:01
  • Related stackoverflow.com/questions/18387938/… Commented Jun 2, 2015 at 7:24

2 Answers 2

94

The original design motivation for allowing order-comparisons of arbitrary objects was to allow sorting of heterogeneous lists -- usefully, that would put all strings next to each other in alphabetical order, and all numbers next to each other in numerical order, although which of the two blocks came first was not guaranteed by the language. For example, this allowed getting only unique items in any list (even one with non-hashable items) in O(N log N) worst-case time

Over the years, this pragmatic arrangement eroded. The first crack came when the ability to order-compare complex numbers was taken away, quite a few versions ago. Suddenly, the ability to sort any list disappeared: it did not apply any more if the list contained complex numbers, possibly together with items of other types. Then Guido started disliking heterogeneous lists more generally, and thus started thinking that it didn't really matter if such lists could be usefully sorted or not... because such lists should not exist in the first place, according to his new thinking. He didn't do anything to forbid them, but was not inclined to accept any compromises to support them either.

Note that both changes move the balance a little bit away from the "practicality beats purity" item of the Zen of Python (which was written earlier, back when complex numbers still could be order-compared ;-) – a bit more purity, a bit less practicality.

Nevertheless the ability to order-compare two arbitrary objects (as long as neither was a complex number ;-) remained for a long time, because around that same time Guido started really insisting on maintaining strong backwards compatibility (a shift that's both practical and pure ;-).

So, it's only in Python 3, which explicitly and deliberately removed the constraint of strong backwards compatibility to allow some long-desired but backwards incompatible enhancements (especially simplifications and removal of obsolete, redundant way to perform certain tasks), that order comparison of instances of different types became an error.

So this historical and philosophical treatise is basically the only way to truly respond to your "why" question...! :-)

Sign up to request clarification or add additional context in comments.

4 Comments

One should maybe add that while the language may not have this feature anymore, sorting of arbitrary lists can easily be down with a custom comparator. Just write it yourself in case you need it - would also be a very practical approach.
Note : In Python 2, a complex number can be compared to any other object, except another complex number! complex(1,0) > 'abc' is False but complex(1,0) > complex(0,0) raises a TypeError
@EricDuminil Not exactly right - complex can not be compared to bools, ints, or fractions. For some reason (oversight, probably) they can be compared with decimals.
@wim: Thanks for the interesting comment. You are technically correct : the best kind of correct! It would almost make sense since we can consider bools, ints, fractions and floats to belong to complex numbers. But decimals should be there, too. It's for python2 anyway, so it's becoming less relevant with time.
23

from https://docs.python.org/2.7/tutorial/datastructures.html#id1

Note that comparing objects of different types is legal. The outcome is deterministic but arbitrary: the types are ordered by their name. Thus, a list is always smaller than a string, a string is always smaller than a tuple, etc. [1] Mixed numeric types are compared according to their numeric value, so 0 equals 0.0, etc.

3 Comments

Weird. Its refreshing that they no longer allow this in Python 3.0
This isn't the whole story; for example, 5 < ArithmeticError() even though 'int' > 'ArithmeticError' and ArithmeticError isn't a numeric type.
For the whole story, look here.

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.