Python菜鸟编程第十四课之魔法方法2
1.反射
反射:是指程序可以访问、检测和修改他本身状态或者行为的一种能力
在Python中,面向对象的反射是指通过字符串的形式操作对象的相关属性。
四个可以实现自省的函数:
-
hasattr:检测是否含有某个属性。语法:hasattr(*args, **kwargs)
-
getattr:获取属性。语法:getattr(object, name, default=None)
-
setattr:设置属性。语法:setattr(x, y, v)
-
delattr:删除属性。语法:delattr(x, y)
demo:
class Foo:
f = '类的静态变量'
def __init__(self, name, age):
self.name = name
self.age = age
def say(self):
print('Hello,%s' % self.name)
obj = Foo('Tom', 22)
# 检测是否含有某个属性
print(hasattr(obj, 'name'))
print(hasattr(obj, 'say'))
# 获取属性
print(getattr(obj, 'name'))
getattr(obj, 'say')()
print(obj.__dict__)
#设置属性
setattr(obj,'good man',True)
setattr(obj,'show_name',lambda self:self.name+'good man')
print(obj.__dict__)
print(obj.show_name(obj))
#删除属性
delattr(obj,'show_name')
print(obj.__dict__)
运行结果:
# 检测是否含有某个属性
True
True
# 获取属性
Tom
Hello,Tom
#设置属性
{'name': 'Tom', 'age': 22}
{'name': 'Tom', 'age': 22, 'good man': True, 'show_name': <function <lambda> at 0x000001B508E3C268>}
Tomgood man
#删除属性
{'name': 'Tom', 'age': 22, 'good man': True}
联想,字符串,列表元组可以通过索引值引用值,字典可以通过关键字引用值,用了[]
2.item系列
demo:
class Foo:
def __init__(self, name):
self.name = name
def __getitem__(self, item):
print(self.__dict__[item])
def __setitem__(self, key, value):
self.__dict__[key] = value
def __delitem__(self, key):
print('del obj[key]时:')
self.__dict__.pop(key)
def __delattr__(self, item):
print('del obj.key时:')
self.__dict__.pop(item)
obj1 = Foo('Tom')
# 执行__setitem__()
obj1['age'] = 18
obj1['age1'] = 19
print(obj1.__dict__)
# 执行__delitem__()
del obj1['age']
# 执行__delattr__()
del obj1.age1
print(obj1.__dict__)
运行结果:
{'name': 'Tom', 'age': 18, 'age1': 19}
del obj[key]时:
del obj.key时:
{'name': 'Tom'}
3._del_
析构方法,当对象在内存中被释放,就会字典触发执行,一般不需要自定义。
因为Python是一门高级语言,程序员在使用时无需关心内存的分配和释放,因为此工作都是交给Python解释器来执行,所以,析构函数的调用是由解释器在进行垃圾回收时自动触发执行的。
demo:
class Foo:
def __del__(self):
print('执行del函数了。')
obj=Foo()
del obj
运行结果:
执行del函数了。
4._str_
如果直接print打印对象,会看到创建对象的内存地址,当使用print(xxx)输出对象时,如果对象中定义了__str__方法
,就会打印该方法return 的信息描述。
demo:
class Cat:
def __init__(self, new_name, new_age):
self.name = new_name
self.age = new_age
def __str__(self):
return '名字是:%s,年龄是%s'%(self.name, self.age)
cat=Cat('Tom',23)
print(cat)
运行结果:
名字是:Tom,年龄是23