python3练习-装饰器
生活随笔
收集整理的這篇文章主要介紹了
python3练习-装饰器
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
在廖雪峰的官方網(wǎng)站學(xué)習(xí)裝飾器章節(jié)時,初步理解類似與面向切面編程。記錄一下自己的課后習(xí)題解法。
問題: 請編寫一個decorator,能在函數(shù)調(diào)用的前后打印出'begin call'和'end call'的日志。寫出一個@log的decorator,使它既支持: @log def f(): pass
又支持: @log('execute') def f(): pass 示例代碼(個人練習(xí),如有問題歡迎斧正): # ! usr/bin/env python3 # -*- coding:utf-8 -*-import functoolsdef log(*text):def decorator(func):@functools.wraps(func)def warpper(*args,**kw):if(isinstance(text,(list,tuple))):print('Info:' , text)print('begin call %s():' % func.__name__)else:print('begin call %s():' % func.__name__)func(*args,**kw)print('-------','end call %s():' % func.__name__,'--------------')return warpperreturn decorator@log(['execute','beginOtherInfo']) def now():print('test function')@log() def now2():print('test function2')
now() now2()
?
轉(zhuǎn)載于:https://www.cnblogs.com/GYoungBean/p/6268662.html
總結(jié)
以上是生活随笔為你收集整理的python3练习-装饰器的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 【BZOJ1031】[JSOI2007]
- 下一篇: Erlang虚拟机的启动