Я столкнулся с каким-то запутанным поведением методов сравнения магии. Предположим, мы имеем следующий класс:Путаница метода магии Python
class MutNum(object):
def __init__ (self, val):
self.val = val
def setVal(self, newval):
self.val = newval
def __str__(self):
return str(self.val)
def __repr__(self):
return str(self.val)
# methods for comparison with a regular int or float:
def __eq__(self, other):
return self.val == other
def __gt__(self, other):
return self.val > other
def __lt__(self, other):
return self.val < other
def __ge__(self, other):
return self.__gt__(other) or self.__eq__(other)
def __le__(self, other):
return self.__lt__(other) or self.__eq__(other)
класс делает то, что он должен делать, сравнивая объект MutNum на регулярной Int или поплавок не является проблемой. Однако, и это то, что я не понимаю, оно даже сравнивается отлично, когда магическим методам даются два объекта MutNum.
a = MutNum(42)
b = MutNum(3)
print(a > b) # True
print(a >= b) # True
print(a < b) # False
print(a <= b) # False
print(a == b) # False
Почему это работает? Благодарю.
Это может помочь подумать о '__gt__' и' __lt__', стоящих в том же отношении, что и '__add__' и' __radd__', например. Если первое не применяется, Python пытается использовать другой, если операнды будут отменены. – chepner