引言:
在阅读源码时,有很多简写的形式,其中一个比较常用的就是getattr()用来调用一个类中的变量或者方法,相关联的hasattr()、getattr()、setattr()函数的使用也一并学习了一下。
正文:
1. hasattr(object, name)
判断object对象中是否存在name属性,当然对于python的对象而言,属性包含变量和方法;有则返回True,没有则返回False;需要注意的是name参数是string类型,所以不管是要判断变量还是方法,其名称都以字符串形式传参;getattr和setattr也同样;
> > class A(): name = 'python' def func(self): return 'A()类的方法func()' > > hasattr(A, 'name') True > > hasattr(A, 'age') False > > hasattr(A, 'func') True >
2. getattr(object, name[, default])
获取object对象的属性的值,如果存在则返回属性值,如果不存在分为两种情况:
(1)没有default参数时,会直接报错;
(2)给定了default参数,若对象本身没有name属性,则会返回给定的default值;
如果给定的属性name是对象的方法,则返回的是函数对象,需要调用函数对象来获得函数的返回值;调用的话就是函数对象后面加括号,如func之于func();
另外还需要注意:
如果给定的方法func()是实例函数,则不能写getattr(A, 'func')(),
因为fun()是实例函数的话,是不能用A类对象来调用的,应该写成getattr(A(), 'func')();
实例函数和类函数的区别:
实例函数定义时,直接def func(self):,这样定义的函数只能是将类实例化后,用类的实例化对象来调用;
而类函数定义时,需要用@classmethod来装饰,函数默认的参数一般是cls,类函数可以通过类对象来直接调用,而不需要对类进行实例化;
> > class A(): name = 'python' def func(self): return 'Hello world' > > getattr(A, 'name') 'python' > > getattr(A, 'age') # age变量不存在则报错 Traceback (most recent call last): File "<pyshell#464>", line 1, in <module> getattr(A, 'age') AttributeError: class A has no attribute 'age' > > getattr(A, 'age', 20) > > getattr(A, 'func') <unbound method A.func> > > getattr(A, 'func')() # func()函数不能被A类对象调用,所以报错, 需要用类的实例化对象来调用 Traceback (most recent call last): File "<pyshell#470>", line 1, in <module> getattr(A, 'func')() TypeError: unbound method func() must be called with A instance as first argument (got nothing instead) > > getattr(A(), 'func')() 'Hello world' > > class A(object): name = 'python' @classmethod def func(cls): return 'the method of A object.' > > getattr(A, 'func')() 'the method of A object.' >
3. setattr(object, name, value)
给object对象的name属性赋值value,如果对象原本存在给定的属性name,则setattr会更改属性的值为给定的value;如果对象原本不存在属性name,setattr会在对象中创建属性,并赋值为给定的value;
> > class A(): name = 'python' def func(self): return 'Hello world' > > setattr(A, 'name', 'java') > getattr(A, 'name') 'java' > > setattr(A, 'age', 20) > getattr(A, 'age') >
一般先判断对象中是否存在某属性,如果存在则返回;如果不存在,则给对象增加属性并赋值:
> > class A(): name = 'python' def func(self): return 'Hello world' > > if hasattr(A, 'age'): print getattr(A, 'age') else: setattr(A, 'age', 20) > > getattr(A, 'age') >
感受一下:
总结
以上所述是小编给大家介绍的python中hasattr()、getattr()、setattr()函数的使用,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。