问题描述
告诉我如何重载运算符>( 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 > 3
,a < 3
,a >= 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
对象或其他具有属性a
和b
的对象进行比较。
听起来像您想要测试使用哪种对象的声音。也许像这样:
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。
我弥补了数字的大小写,因为我不知道你怎么定义它。