重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
官网解释:
创新互联公司提供高防服务器租用、云服务器、香港服务器、成都棕树机房等
object.
__getattr__
(self, name)
Called when an attribute lookup has not found the attribute in the usual places (i.e. it is not an instance attribute nor is it found in the class tree for self
). name
is the attribute name. This method should return the (computed) attribute value orraise an AttributeError
exception.
当我们想调用Class中某些东西,而Class中没有,解释器铁定报错,停止运行,那有人就想了:真麻烦,每次都要重新执行一遍,如果当我调用错了内容,程序能把我这个错误当默认程序执行,而不停止我程序运行就好了。so,为了解决这类问题,就出来了__getattr__这个函数了。
我猜的,因为解决程序困难也是一种需求。
看没有__getattr的出错调用:
#!/usr/bin/python
# -*- coding: utf-8 -*-
class Student(object):
def __init__(self):
self.name = 'Michael'
s = Student()
print s.name
print s.score #Class中没有这个属性
look, 第一个print正常执行,第二个由于Class中没有这个属性,所以就报错了。
再看,带__getattr__的Class:
#!/usr/bin/python
# -*- coding: utf-8 -*-
class Student(object):
def __init__(self):
self.name = 'Michael'
def __getattr__(self, other):
if other=='score':
return 99
s = Student()
print s.name
print s.score #Class中没有这个属性
print s.gg #Class中没有这个属性
look again, print 的score 和 gg 在Class中都没有定义,但都有输出。因为程序往__getattr__中找,刚刚好定义了一个字符判断 if other=='score':, 所以输出了99 ,而gg一个字都没提,就默认输出None了。是不是感觉以后码程序的时候再也不用担心程序停止运行了。
※发现的强大的链式调用写法:
class Chain(object): def __init__(self, path=''): self._path = path def __getattr__(self, path): return Chain('%s/%s' % (self._path, path)) #调用自己 def __str__(self): return self._path __repr__ = __str__ f = Chain() print (f.www.anc.do.glob)
结果:
/www/anc/do/glob