常用魔法(在一定条件下自动触发)
他们是可以给你的类增加魔力的特殊方法,如果你的对象实现(重载)了这些方法中的某一个,那么这个方法就会在特殊的情况下被 Python 所调用,你可以定义自己想要的行为,而这一切都是自动发生的。 Python 的魔术方法非常强大,然而随之而来的则是责任。了解正确的方法去使用非常重要!
算数运算的基本使用
# self 就是传入的参数, 默认0 , other 是和 self 运算的参数# 自动进行运算class A(int):# 出现加法时自动调用def __add__(self, other):print(self, other)# 这几种写法都是可以的# return int.__add__(self, other)# return int(self) + int(other)# return int(self) - int(other)# 不可直接计算 , 因为出现了加法会继续调用自身# return self + other# 类型也是对象# 魔法方法可以对对象进行计算# self = 12 , other = 24a = A(12)print(a + 24)
反运算
和普通运算一样 , 只不过反过来
# self 就是传入的参数, 默认0 , other 是和 self 运算的参数# 自动进行运算class A(int):# 出现加法时自动调用def __radd__(self, other):print(self, other)print('反运算 self = 12 , other = 24')# 这几种写法都是可以的return int.__add__(self, other)# return int(self) + int(other)# return int(self) - int(other)# 不可直接计算 , 因为出现了加法会继续调用自身# return self + other# 类型也是对象# 魔法方法可以对对象进行计算# self = 12 , other = 24a = A(12)print(24 + a)
| 魔法方法 | 含义 |
|---|---|
| 基本的魔法方法 | |
__new__(cls[, …]) |
1. new__ 是在一个对象实例化的时候所调用的第一个方法 2. 它的第一个参数是这个类,其他的参数是用来直接传递给 init__ 方法 3. new__ 决定是否要使用该 init__ 方法,因为 new__ 可以调用其他类的构造方法或者直接返回别的实例对象来作为本类的实例,如果 new__ 没有返回实例对象,则 init__ 不会被调用 4. new__ 主要是用于继承一个不可变的类型比如一个 tuple 或者 string |
__init__(self[, …]) |
构造器,当一个实例被创建的时候调用的初始化方法 |
__del__(self) |
析构器,当一个实例被销毁的时候调用的方法 |
__call__(self[, args…]) |
允许一个类的实例像函数一样被调用:x(a, b) 调用 x.`call`(a, b) |
__len__(self) |
定义当被 len() 调用时的行为 |
__repr__(self) |
定义当被 repr() 调用时的行为 |
__str__(self) |
定义当被 str() 调用时的行为 |
__bytes__(self) |
定义当被 bytes() 调用时的行为 |
__hash__(self) |
定义当被 hash() 调用时的行为 |
__bool__(self) |
定义当被 bool() 调用时的行为,应该返回 True 或 False |
__format__(self, format_spec) |
定义当被 format() 调用时的行为 |
| 有关属性 | |
__getattr__(self, name) |
定义当用户试图获取一个不存在的属性时的行为 |
__getattribute__(self, name) |
定义当该类的属性被访问时的行为 |
__setattr__(self, name, value) |
定义当一个属性被设置时的行为 |
__delattr__(self, name) |
定义当一个属性被删除时的行为 |
__dir__(self) |
定义当 dir() 被调用时的行为 |
__get__(self, instance, owner) |
定义当描述符的值被取得时的行为 |
__set__(self, instance, value) |
定义当描述符的值被改变时的行为 |
__delete__(self, instance) |
定义当描述符的值被删除时的行为 |
| 比较操作符 | |
__lt__(self, other) |
定义小于号的行为:x < y 调用 x.`lt`(y) |
__le__(self, other) |
定义小于等于号的行为:x <= y 调用 x.`le`(y) |
__eq__(self, other) |
定义等于号的行为:x == y 调用 x.`eq`(y) |
__ne__(self, other) |
定义不等号的行为:x != y 调用 x.`ne`(y) |
__gt__(self, other) |
定义大于号的行为:x > y 调用 x.`gt`(y) |
__ge__(self, other) |
定义大于等于号的行为:x >= y 调用 x.`ge`(y) |
| 算数运算符 | |
__add__(self, other) |
定义加法的行为:+ |
__sub__(self, other) |
定义减法的行为:- |
__mul__(self, other) |
定义乘法的行为:* |
__truediv__(self, other) |
定义真除法的行为:/ |
__floordiv__(self, other) |
定义整数除法的行为:// |
__mod__(self, other) |
定义取模算法的行为:% |
__divmod__(self, other) |
定义当被 divmod() 调用时的行为 |
__pow__(self, other[, modulo]) |
定义当被 power() 调用或 ** 运算时的行为 |
__lshift__(self, other) |
定义按位左移位的行为:<< |
__rshift__(self, other) |
定义按位右移位的行为:>> |
__and__(self, other) |
定义按位与操作的行为:& |
__xor__(self, other) |
定义按位异或操作的行为:^ |
__or__(self, other) |
定义按位或操作的行为:| |
| 反运算 | |
__radd__(self, other) |
(与上方相同,当左操作数不支持相应的操作时被调用) |
__rsub__(self, other) |
(与上方相同,当左操作数不支持相应的操作时被调用) |
__rmul__(self, other) |
(与上方相同,当左操作数不支持相应的操作时被调用) |
__rtruediv__(self, other) |
(与上方相同,当左操作数不支持相应的操作时被调用) |
__rfloordiv__(self, other) |
(与上方相同,当左操作数不支持相应的操作时被调用) |
__rmod__(self, other) |
(与上方相同,当左操作数不支持相应的操作时被调用) |
__rdivmod__(self, other) |
(与上方相同,当左操作数不支持相应的操作时被调用) |
__rpow__(self, other) |
(与上方相同,当左操作数不支持相应的操作时被调用) |
__rlshift__(self, other) |
(与上方相同,当左操作数不支持相应的操作时被调用) |
__rrshift__(self, other) |
(与上方相同,当左操作数不支持相应的操作时被调用) |
__rand__(self, other) |
(与上方相同,当左操作数不支持相应的操作时被调用) |
__rxor__(self, other) |
(与上方相同,当左操作数不支持相应的操作时被调用) |
__ror__(self, other) |
(与上方相同,当左操作数不支持相应的操作时被调用) |
| 增量赋值运算 | |
__iadd__(self, other) |
定义赋值加法的行为:+= |
__isub__(self, other) |
定义赋值减法的行为:-= |
__imul__(self, other) |
定义赋值乘法的行为:*= |
__itruediv__(self, other) |
定义赋值真除法的行为:/= |
__ifloordiv__(self, other) |
定义赋值整数除法的行为://= |
__imod__(self, other) |
定义赋值取模算法的行为:%= |
__ipow__(self, other[, modulo]) |
定义赋值幂运算的行为:**= |
__ilshift__(self, other) |
定义赋值按位左移位的行为:<<= |
__irshift__(self, other) |
定义赋值按位右移位的行为:>>= |
__iand__(self, other) |
定义赋值按位与操作的行为:&= |
__ixor__(self, other) |
定义赋值按位异或操作的行为:^= |
__ior__(self, other) |
定义赋值按位或操作的行为:|= |
| 一元操作符 | |
__pos__(self) |
定义正号的行为:+x |
__neg__(self) |
定义负号的行为:-x |
__abs__(self) |
定义当被 abs() 调用时的行为 |
__invert__(self) |
定义按位求反的行为:~x |
| 类型转换 | |
__complex__(self) |
定义当被 complex() 调用时的行为(需要返回恰当的值) |
__int__(self) |
定义当被 int() 调用时的行为(需要返回恰当的值) |
__float__(self) |
定义当被 float() 调用时的行为(需要返回恰当的值) |
__round__(self[, n]) |
定义当被 round() 调用时的行为(需要返回恰当的值) |
__index__(self) |
1. 当对象是被应用在切片表达式中时,实现整形强制转换 2. 如果你定义了一个可能在切片时用到的定制的数值型,你应该定义 __index__3. 如果 __index__ 被定义,则 __int__ 也需要被定义,且返回相同的值 |
| 上下文管理(with 语句) | |
__enter__(self) |
1. 定义当使用 with 语句时的初始化行为 2. __enter__ 的返回值被 with 语句的目标或者 as 后的名字绑定 |
__exit__(self, exc_type, exc_value, traceback) |
1. 定义当一个代码块被执行或者终止后上下文管理器应该做什么 2. 一般被用来处理异常,清除工作或者做一些代码块执行完毕之后的日常工作 |
| 容器类型 | |
__len__(self) |
定义当被 len() 调用时的行为(返回容器中元素的个数) |
__getitem__(self, key) |
定义获取容器中指定元素的行为,相当于 self[key] |
__setitem__(self, key, value) |
定义设置容器中指定元素的行为,相当于 self[key] = value |
__delitem__(self, key) |
定义删除容器中指定元素的行为,相当于 del self[key] |
__iter__(self) |
定义当迭代容器中的元素的行为 |
__reversed__(self) |
定义当被 reversed() 调用时的行为 |
__contains__(self, item) |
定义当使用成员测试运算符(in 或 not in)时的行为 |
常用类相关函数
| 函数 | 描述 |
|---|---|
| issubclass(class,sonClass) | 判断 sonClass 和 class 是否有关系 |
| isinstance(object,classinfo) | 判断 classinfo 是否属于 object , 判断一个对象是否属于某实例 |
| hasattr(object,name) | 判断一个对象中是否存在某属性 |
| getattr(object,name,[default]) | 判断一个对象中是否存在某属性 , 不存在返回default或报错 , 存在返回 1 |
| setattr(object,name,value) | 新建一个属性 , 存在则替换 |
| delattr(object,name) | 删除一个属性 |
| property(fget = getVal, fset = setVal, fdel = delVal) | 自定义一个属性 , fget 赋值方法 , gset 修改值的方法 , fdel 删除值的方法 |
迭代器
class Fibs:def __init__(self):self.a = 0self.b = 1def __iter__(self):return selfdef __next__(self):self.a += self.a + self.bif self.a > 30:#停止raise StopIterationreturn self.af = Fibs()for each in f:print(each)
生成器
只要函数中有 yield 它便是一个生成器 , 相当于 return , 不同的是可以多次返回 , 每次返回结果都是下一次的 yield
# 只要函数中有 yield 它便是一个生成器 , 相当于 return , 不同的是可以多次返回 , 每次返回结果都是下一次的 yielddef myGen():print('生成器开始运行')yield 1print('生成器开始运行')yield 2print('生成器开始运行')yield 3my = myGen()print(my)print(next(my))print(next(my))
