本文实例讲述了Python 装饰器@,对函数进行功能扩展操作。分享给大家供大家参考,具体如下:
装饰器可以对原函数进行功能扩展,但还不需要修改原函数的内容(开闭原则),也不需要修改原函数的调用。
demo.py(装饰器,@):
# 闭包 def w1(func): def inner(): # 对原函数进行功能扩展 print("功能扩展") func() # return func() # 如果原函数需要返回值,可以return return inner # 闭包 @w1 # 相当于 f1 = w1(f1) def f1(): print('f1') # 原函数不需要修改 f1() # 原函数的调用也不需要修改
demo.py(装饰器通用格式,对不定长参数并且有返回值的函数进行装饰):
def set_func(func): def call_func(*args, **kwargs): print("装饰器扩展的功能") return func(*args, **kwargs) # 这里的*和*表示拆包。 不管有没有返回值,return都没问题。 return call_func @set_func # 相当于 test1 = set_func(test1) # 对含有不定长参数并且有返回值的函数进行装饰。 def test1(num, *args, **kwargs): print("-----test1----%d" % num) return "ok" ret = test1(100) print(ret)
demo.py(多个装饰器的装饰顺序):
def add_1(func): def call_func(*args, **kwargs): print("装饰器1 扩展的功能") return func(*args, **kwargs) return call_func def add_2(func): def call_func(*args, **kwargs): print("装饰器2 扩展的功能") return func(*args, **kwargs) return call_func @add_2 @add_1 # 先装饰add_1,再装饰add_2 def test1(): print("------test1------") test1() # 在调用函数之前就已经装饰好了。 # 装饰器2 扩展的功能 # 装饰器1 扩展的功能 # ------test1------
demo.py(用类充当装饰器):
# 用类充当装饰器 class Test(object): def __init__(self, func): self.func = func def __call__(self, *args, **kwargs): print("这里是装饰器添加的功能.....") return self.func(*args, **kwargs) @Test # 相当于get_str = Test(get_str) # 实例化对象,调用__init__方法。 def get_str(): return "haha" print(get_str()) # 实例对象(),会自动调用对象的__call__方法。
@functools.wraps
修饰装饰器的内层函数。(修饰内层函数后,被装饰器装饰的函数的__name__、__doc__不会被装饰器改变)
demo.py(@functools.wraps修饰装饰器的内层函数):
# coding:utf-8 import functools # 导入 # 自定义的装饰器 def login_required(func): @functools.wraps(func) # 装饰器的内层函数,一般要加@functools.wraps装饰器 def wrapper(*arg, **kwargs): """wrapper的说明文档""" # 。。。 return func(*arg, **kwargs) return wrapper # 使用自定义的装饰器 @login_required def demofunc(): """demofunc的说明文档""" pass print(demofunc.__name__) # 不加@functools.wraps装饰器时:"wrapper"。 加装饰器时:"demofunc" print(demofunc.__doc__) # 不加@functools.wraps装饰器时:"wrapper的说明文档"。 加装饰器时:"demofunc的说明文档"
更多关于Python相关内容感兴趣的读者可查看本站专题:《Python面向对象程序设计入门与进阶教程》、《Python数据结构与算法教程》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》、《Python编码操作技巧总结》及《Python入门与进阶经典教程》
希望本文所述对大家Python程序设计有所帮助。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。