Когда я пытаюсь переопределить магический метод __eq__
и используйте super
для доступа к базовому методу, найденному в object
, я получаю сообщение об ошибке. Нет никакого способа, чтобы это было ошибкой, но это точно похоже на одно:
class A(object):
def __eq__(self, other):
return super(A, self).__eq__(other)
A() == 0
# raises AttributeError: 'super' object has no attribute '__eq__'
Это неинтуитивно, потому что object.__eq__
существует, но для class A(object): pass
это не так. Если я не ошибаюсь, __eq__
прибегает к проверке is
, так что это может быть обходным путем, но использование is
вместо super
не является дружественным к mixin. Переход к этому маршруту в порядке, но в других это может и не быть.
Любые предложения или информация о том, почему __eq__
работает таким образом, были бы замечательными.