python:重载运算符>具有不同类型

问题描述

告诉我如何重载运算符>( lt )或 gt )等,以便它可以与不同类型(尤其是0)一起使用

例如:

class CRational(object):

    def __init__(self,a = 0,b = 1):
        self.a = a
        self.b = b
        
    def __neg__(self):
        return CRational(-self.a,self.b)

    def __add__(self,other):
        return CRational(self.a * other.b + other.a * self.b,self.b * other.b)

    def __sub__(self,other):
        return CRational(self.a * other.b - other.a * self.b,self.b * other.b)

    def __mul__(self,other):
        return CRational(self.a * other.a,self.b * other.b)

    def __truediv__(self,other):
        return CRational(self.a * other.b,self.b * other.a)

    def __eq__(self,other):
        return self.a * other.b == other.a * self.b

    def __ne__(self,other):
        return not self.__eq__(other)

    def __lt__(self,other):
        return self.a * other.b < other.a * self.b

    def __le__(self,other):
        return self.a * other.b <= other.a * self.b

    def __gt__(self,other):
        return self.a * other.b > other.a * self.b

    def __ge__(self,other):
        return self.a * other.b >= other.a * self.b

错误输出

文件“ lessons / python / square_eq.py”,第66行,位于__gt __ 返回self.a * other.b> other.a * self.b AttributeError:'int'对象没有属性'b'

使用代码

s_a = "" if a > 0 else "-"

您如何解决

s_a = "" if a > CRational(0) else "-"

上述方法有帮助,但效果不佳:)

解决方法

如果您想将CRational对象与一个int进行比较,那么您的__gt__方法也应该适用于整数。也就是说,如果other是整数,则显然不能执行类似other.b的操作。这是一个可能的解决方案:

class CRational:
    def __init__(self,a = 0,b = 1):
        self.a = a
        self.b = b
    def __gt__(self,other):
        if isinstance(other,CRational):
            return self.a * other.b > other.a * self.b
        elif isinstance(other,int):
            # Compare self (a CRational object) with other (an int)
            # TODO
        else:
            raise NotImplemented()

现在您可以执行以下操作:

a = CRational()
if a > 3:
    ...

但是要小心!即使正确实现了所有方法,您仍然无法执行3 > a。订单很重要!! 3 > a将调用int类的__gt__方法。您只能执行a > 3a < 3a >= 3等。

,

关于您的错误输出:由于您的“其他”是一个int并且CRational.__gt__试图访问一个没有b的属性,因此您收到错误:

def __gt__(self,other):  # passing in an int here
        return self.a * other.b > other.a * self.b

对于您的代码示例,假设a是另一个CRational对象,那么a > 0将导致您在上面看到的AttributeError是修复它的唯一方法是通过将其与另一个CRational对象或其他具有属性ab的对象进行比较。

,

听起来像您想要测试使用哪种对象的声音。也许像这样:

import numbers

def __gt__(self,other):
    if isinstance(other,type(self)):
        return self.a * other.b > other.a * self.b
    elif isinstance(other,numbers.Number):
        return self.a > other
    else:
        err_str = "Unknown type in comparison with %s object: %s" % (type(self).__name__,type(other).__name__)
        raise(TypeError(err_str))

在这里,type(self)是获取CRational类的通用方法。这样一来,即使您以后再更改名称,也不必修改类的代码。

isinstance检查给定对象是给定类型还是子类型。 Python documentation

我弥补了数字的大小写,因为我不知道你怎么定义它。

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...