1、python私有化
xx:公有变量
_x:单前置下划线,私有化属性或方法,from module import * 禁止导入,但是类对象和子类可以访问。
__xx:双前置下划线,避免与子类中的属性命名冲突,无法在外部直接访问(名字重整所以访问不到)
__xx__:双前后下划线,用户名字空间的魔法对象或属性。
xx_:单后置下划线,用于避免与python关键词的冲突。
通过name mangling(名字重整的目的就是以防子类意外重写基类的方法或者属性)。
通过_Class__object机制可以访问private。
父类中属性名为__name的,子类不能继承,子类不能访问。
如果在子类中向__name赋值,那么会在子类中定义一个与父类相同名字的属性。
_name的变量、函数、类在使用from xxx import * 时都不会被导入。
2、魔法属性
2.1 __doc__
描述类的描述信息。
2.2 __module__和__class__
__module__表示当前操作的对象在哪个模块
__class__表示当前操作的对象的类是什么
2.3 __init__
初始化方法,通过类创建对象时,自动触发执行
2.4 __del__
当对象在内存中被释放时,自动触发执行。
说明:此方法一般无需定义,因为python是一门高级语言,程序员在使用时无需关心内存的分配和释放,因为此工作都是交给Python解释器来执行,所以,__del__的调用是由解释器在进行垃圾回收时自动触发执行的。
2.5 __call__
对象后面加括号,触发执行。
注:__init__方法的执行是由创建对象触发的,即:对象 = 类名()
;而对于 __call__ 方法的执行是由对象后加括号触发的,即:对象()
或者 类()()
class Foo: def __init__(self): pass def __call__(self, *args, **kwargs): print('__call__') obj = Foo() # 执行 __init__ obj() # 执行 __call__
2.6 __dict__
类或对象中的所有属性。
类的实例属性属于对象,类中的类属性和方法属于类。
class Province(object): country = 'China' def __init__(self, name, count): self.name = name self.count = count def func(self, *args, **kwargs): print('func') # 获取类的属性,即:类属性、方法、 print(Province.__dict__) # 输出:{'__dict__': <attribute '__dict__' of 'Province' objects>, '__module__': '__main__', 'country': 'China', '__doc__': None, '__weakref__': <attribute '__weakref__' of 'Province' objects>, 'func': <function Province.func at 0x101897950>, '__init__': <function Province.__init__ at 0x1018978c8>} obj1 = Province('山东', 10000) print(obj1.__dict__) # 获取 对象obj1 的属性 # 输出:{'count': 10000, 'name': '山东'} obj2 = Province('山西', 20000) print(obj2.__dict__) # 获取 对象obj1 的属性 # 输出:{'count': 20000, 'name': '山西'}
2.7 __str__
如果一个类中定义了__str__方法,那么在打印 对象 时,默认输出该方法的返回值。
class Foo: def __str__(self): return 'laowang' obj = Foo() print(obj) # 输出:laowang
2.8 __getitem__、__setitem__、__delitem__
用于索引操作,如字典。以上分别表示获取、设置、删除数据。
class Foo(object): def __getitem__(self, key): print('__getitem__', key) def __setitem__(self, key, value): print('__setitem__', key, value) def __delitem__(self, key): print('__delitem__', key) obj = Foo() result = obj['k1'] # 自动触发执行 __getitem__ obj['k2'] = 'laowang' # 自动触发执行 __setitem__ del obj['k1'] # 自动触发执行 __delitem__
2.9 __getslice__、__setslice__、__delslice__
该三个方法用于分片操作,如:列表
class Foo(object): def __getslice__(self, i, j): print('__getslice__', i, j) def __setslice__(self, i, j, sequence): print('__setslice__', i, j) def __delslice__(self, i, j): print('__delslice__', i, j) obj = Foo() obj[-1:1] # 自动触发执行 __getslice__ obj[0:1] = [11,22,33,44] # 自动触发执行 __setslice__ del obj[0:2] # 自动触发执行 __delslice__