一、类的特殊方法
我们dir(str)会发现,输出的属性,方法列表有很多的特殊的方法,名称类似 __name__()。实际上这是一些约定的特殊方法,这些特殊方法有它的特殊作用,因此重写父类的时候,不要重写父类如下的特殊方法:
>>> dir(str)
['__add__', '__class__', '__contains__', '__delattr__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__getitem__', '__getnewargs__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__iter__', '__le__', '__len__', '__lt__', '__mod__', '__mul__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__rmod__', '__rmul__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', 'capitalize', 'casefold', 'center', 'count', 'encode', 'endswith', 'expandtabs', 'find', 'format', 'format_map', 'index', 'isalnum', 'isalpha', 'isdecimal', 'isdigit', 'isidentifier', 'islower', 'isnumeric', 'isprintable', 'isspace', 'istitle', 'isupper', 'join', 'ljust', 'lower', 'lstrip', 'maketrans', 'partition', 'replace', 'rfind', 'rindex', 'rjust', 'rpartition', 'rsplit', 'rstrip', 'split', 'splitlines', 'startswith', 'strip', 'swapcase', 'title', 'translate', 'upper', 'zfill']
红色字体部分的特殊方法,不要重写。下面是常见的类的特殊方法的解释:
实例1:定义一个矩形类并定义一些特殊方法.
class Rectangle:
'''这是一个矩形类的注释,
多行'''
def __init__(self, length, width):
if isinstance(length, (int, float)) and isinstance(width, (int, float)):
self.length = length
self.width = width
else:
raise TypeError
# return None
def area(self):
areas = self.length * self.width
return areas
def __str__(self): # print(b) 覆盖object里面本来的方法
return '宽为%s,高为%s' % (self.width, self.length)
def __repr__(self): # b
return '面积为:%s' % (self.area())
def __call__(self):
return '这是call方法'
def __add__(self, other):
add_length = self.length + other.length
add_width = self.width + other.width
return add_length, add_width
b = Rectangle(3,5)
c = Rectangle(4,6)
print(b.__dict__) ##__dict__返回实例的全部属性
print(c.__dict__) ##__dict__返回实例的全部属性
print(b.__doc__) ##__doc__返回类的注释
print(b) ##__str__是默认的print(instance)的调用方法。
#b 在IDLE中直接b的时候返回的是__repr__方法
print(b()) ##__call__是实例的调用方法。
输出:
{'length': 3, 'width': 5}
{'length': 4, 'width': 6}
这是一个矩形类的注释,
多行
宽为5,高为3
这是call方法
实例2:定义类的运算符方法
__add__(self,other) x+y
__sub__(self,other) x-y
__mul__(self,other) x*y
__mod__(self,other) x%y
__iadd__(self,other) x+=y
__isub__(self,other) x-=y
__radd__(self,other) y+x
__rsub__(self,other) y-x
__imul__(self,other) x*=y
__imod__(self,other) x%=y
__truediv__(self,other) x/y
__floordiv__(self,other) x//y
class Rectangle: def __init__(self, length, width): if isinstance(length, (int, float)) and isinstance(width, (int, float)): self.length = length self.width = width def area(self): areas = self.length * self.width return areas class Square(Rectangle): def judgement(self): if self.length == self.width: return True else: return False def __add__(self, other): # 加法 return self.area() + other.area() # return Square(self.area() + other.area(),self.area() + other.area()) def __sub__(self, other): # 减法 return abs(self.area() - other.area()) # abs取绝对值 def __mul__(self, other): # * return self.area() * other.area() def __truediv__(self, other): # / return self.area() / other.area() def __floordiv__(self, other): # // return self.area() // other.area() def __radd__(self, other): # 先在前面找add,不能的话就找radd return other + self.area() def __rmul__(self, other): # 先在前面找add,不能的话就找* return self.area() * other.area() a = Square(3, 3) b = Square(5, 5) c = Square(8, 8) print(a+b) ##同类型的不同实例的自定义:__add__ print(a+c) ##同类型的不同实例的自定义:__add__ print(a-b) ##同类型的不同实例的自定义:__sub__ print(b*c) ##同类型的不同实例的自定义:__mul__ print(a/c) ##同类型的不同实例的自定义:__truediv__ 输出: 34 73 16 1600 0.140625