Python_类的魔术方法

基本的魔法方法

__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. 一般被用来处理异常,清除工作或者做一些代码块执行完毕之后的日常工作

示例:

class Myopen(object):
    def __init__(self, name, mode='r'):
        self.name = name
        self.mode = mode

    def __enter__(self):
    # 当with语句进入并开始执行时,执行的内容, 需要返回一个对象,在执行结束之后用来关闭或者其他操作;
        self.f = open(self.name, self.mode)
        print("正在打开文件%s......" %(self.name))
        return  self.f

    def __exit__(self, exc_type, exc_val, exc_tb): 	
    # 当with语句执行结束后,做什么操作
    self.f.close()
    print("文件正在关闭..........") 
           
with Myopen('/tmp/passwd') as f:
    print(f.read())

Python_类的魔术方法_第1张图片

容器类型

__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)时的行为

property属性:

总结:
  1. Python内置的@property装饰器就是负责把一个方法变成属性调用的;
  2. @property本身又创建了另一个装饰器@state.setter,负责把一个
    setter方法变成属性赋值,于是,我们就拥有一个可控的属性操作;
  3. @property广泛应用在类的定义中,可以让调用者写出简短的代码,
    同时保证对参数进行必要的检查,这样,程序运行时就减少了出错的可能性。

源代码应用范例:
让属性只读:

from datetime import  date

# Read-only field accessors
@property
def year(self):
    # year (1-9999)
    return self._year

@property
def month(self):
    # month (1-12)
    return self._month

@property
def day(self):
    # day (1-31)
    return self._da
    
/home/kiosk/anaconda2/ envs /2048/lib/python3.6/datetime.py

示例:

from datetime import  date
from datetime import  time
import time


from day13.colorFont import  *
class Book(object):
    def __init__(self, name, kind, state):
        self.name = name
        self.kind = kind
        # 0: 借出  1: 未借出
        # 书的状态只能是0或者1,如果是其他,应该报错;
        # 查看书状态,希望是汉字形式,有实际意义的;
        self.__state = 0

    @property		# 将这个方法转换为类的属性; print(book.state)
    def state(self):
        if self.__state == 0:
            return  ERRRED + "借出"
        elif self.__state == 1:
            return  OKGREEN + "未借出"

    @state.setter		# book.state = 0
    def state(self, value):
        if value in (0,1):
            # 更新书状态
            self.__state = value
        else:
            print(ERRRED + "更新错误, 必须是0或者1")

    @state.deleter		# del book.state
    def state(self):
        del self.__state
        print(OKGREEN + "删除书状态成功!")

if __name__ == "__main__":
    book = Book("python核心编程", 'python', 1)
    # book.set_state(3)		# book.state = 3
    # print(book.get_state())		# print(book.state)
    book.state = 0
    print(book.state)
    del book.state


    d = date(2019, 10, 10)
    print(d.year)
    print(d.month)
    print(d.day)


    # d.year = 2020     # 此处不成功, year是只读的
    # del d.year        # 此处不成功, year是只读的
    print(d.year)

Python_类的魔术方法_第2张图片

你可能感兴趣的:(Python_类的魔术方法)