魔法方法详解
魔法方法 | 含义 |
---|---|
| 基本的魔法方法 |
| 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, formatspec) | 定义当被 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)时的行为 |
算术运算符
class New_int(int):
def __add__(self,other):
return int.__sub__(self,other)
def __sub__(self,other):
return int.__add__(self,other)
a = New_int(5)
print(a)
b = int(3)
print(a - b)
----------------------加法的时候调用减法 , 减法的时候调用加法
8
class New_int(int):
def __add__(self, other):
return int(self)+int(other)
def __sub__(self, other):
return int(self)-int(other)
a = New_int(5)
print(a)
b = int(3)
print(a + b)
--------------------------
算术正常 打印 8
反运算符
class Nint(int):
def __radd__(self, other):
return int.__sub__(self, other)
a = Nint(5)
b = Nint(2)
print(a + b)
print(1 + b)
-----------------------
7 由于 变量a 有 radd方法, b也有
1 这里的 1 是没有radd 方法的 这里的是 2 , 1加1 等于 2 的值 所以返回打印了 1,
那如果 第7行的 2 是 4 的话, 那么最终会返回 3
反运算要注意 顺序位置, 那个顺序位置呢? return 这里的顺序位置 self, other
class Nint(int):
def __rsub__(self, other):
return int.__sub__(self, other)
a = Nint(5)
print(3 -a)
----------------------
2
class Nint(int):
def __rsub__(self, other):
return int.__sub__(other,self)
a = Nint(5)
print(3 -a)
---------------------
-2
增量运算符
意思 就跟JavaScript 那样 i += 1
a = 5
b = 3
a = a + b
print(a)
----------------
8
a = 5
b = 3
a += b
print(a)
---------------
8