python中有很多以下划线开头和结尾的特殊属性和魔法函数,它们有着很重要的作用。
1.__doc__:说明性文档和信息,python自建,不需要我们定义。
# -*- coding:utf- -*- class Person:
"""这里是描述性信息"""
def func(self):
pass if __name__ == '__main__':
print(Person.__doc__)
2.__init__():实例化方法,创建实例时自动执行。
# -*- coding:utf- -*- class Person:
def __init__(self):
print("自动执行了__init__()方法") if __name__ == '__main__':
person = Person()
3.__module__和__class__
__module__:当前操作的对象属于哪一个模块,__class__:当前操作的对象属于哪一个类。
# -*- coding:utf- -*- class Person:
def __init__(self):
print("自动执行了__init__()方法") if __name__ == '__main__':
person = Person()
print(person.__module__)
print(person.__class__) -------输出--------
__main__
<class '__main__.Person'>
4.__del__():当对象在内存中被释放时,自动执行该方法,该方法无限自定义,除非我们想要在对象释放时执行一些操作。
# -*- coding:utf- -*- class Person: def __del__(self):
print("我被回收了") if __name__ == '__main__':
person = Person()
5.__call__():如果一个类编写了该方法,则该类的实例后面加括号时会调用此方法。
# -*- coding:utf- -*- class Person: def __call__(self, *args, **kwargs):
print("执行了__call__") if __name__ == '__main__':
person = Person()
person()
print(callable(Person))
可以通过callable()函数判断一个类是否为可执行的。
6.__dict__:列出类或者对象中的所有成员。
# -*- coding:utf- -*-class Person:
country = "中国"
def __init__(self, name, age):
self.name = name
self.age = age def func(self):
print("func")if __name__ == '__main__':
print(Person.__dict__)
person = Person("zhangsan", )
print(person.__dict__)-------输出结果--------
{'country': '中国', '__init__': <function Person.__init__ at 0x00000247F6218B70>, '__module__': '__main__', '__dict__': <attribute '__dict__' of 'Person' objects>, '__weakref__': <attribute '__weakref__' of 'Person' objects>, 'func': <function Person.func at 0x00000247F6218BF8>, '__doc__': None}
{'age': , 'name': 'zhangsan'}
7.__str__():如果一个类定义了这个方法,则在打印对象时会自动执行该方法。
# -*- coding:utf- -*- class Person: def __init__(self, name, age):
self.name = name
self.age = age def __str__(self):
return "name:"+self.name+"----age:"+self.age if __name__ == '__main__':
person = Person("zhangsan", "")
print(person) ------输出结-------
name:zhangsan----age:
8.__getitem__(),__setitem()__.__delitem__():取数据,设置数据,删除数据。
aa = 标识符[] # 执行__getitem__()
标识符[] = bb # 执行__setitem__()
del 标识符[] # 执行__delitem__()
# -*- coding:utf- -*- class Person:
def __setitem__(self, key, value):
print("执行了__setitem__()") def __getitem__(self, item):
print("执行了__getitem__()") def __delitem__(self, key):
print("执行了__delitem__()") if __name__ == '__main__':
person = Person()
r = person['a']
person['a'] = "AAA"
del person['a'] --------输出结果-------
执行了__getitem__()
执行了__setitem__()
执行了__delitem__()
9.__iter__():如果想让自定义的类的对象可以被迭代,则需要定义该方法,并返回一个可迭代的对象。
# -*- coding:utf- -*- class Person: def __iter__(self):
yield
yield
yield if __name__ == '__main__':
person = Person()
for p in person:
print(p) ------输出结果-------
10.__len__():获取对象的长度。
In []: 'ABCDE'.__len__()
Out[]: In []: len('ABCDE')
Out[]:
11.__repr__():返回开发可以看到的字符串,与__str__()的区别是__str__()返回用户可以看到的字符串,通常两者代码一样。
# -*- coding:utf- -*- class Person: def __init__(self, name):
self.name = name def __str__(self):
return "this is %s" % self.name __repr__ = __str__ if __name__ == '__main__':
person = Person("张三")
print(person) print(person.__repr__()) ------输出结果-------
this is 张三
this is 张三
12.__add__:加法,__sub__:减法,__mul__:乘法,__div__:除法,__mod__:求与运算,__pow__:幂运算
class Calculator: def __init__(self, a):
self.a = a def __add__(self, other):
return self.a + other.a if __name__ == '__main__':
a = Calculator()
b = Calculator()
print(a + b)
13.__author__:表示作者信息。
# -*- coding:utf- -*- __author__ = "boxiaoyuan" class Calculator: def show(self):
print(__author__) if __name__ == '__main__':
a = Calculator()
a.show()
14.__slots__:可以限制实例的变量只可以添加哪些属性。
# -*- coding:utf- -*- def show(self):
print("hello world") class Person: def __init__(self):
pass __slots__ = ("name","age") p = Person()
p.name = "zhangsan"
p.age = ""
# p.sex = "男"
Person.show = show # 无法限制为类添加方法
p.show()