python 装置器

1 解决的问题

1 解决调用函数时想使用额外的附加条件时的复用问题
2 解决函数属性发生改变的问题

2 代码

import logging
def use_logging(func):

    def wrapper(*args,**kwargs):
        logging.warn("%s in running" % func.__name__)
        return func(*args,**kwargs)
    return wrapper

def bar():
    print ("i am bar")

bar =use_logging(bar)
print bar()
print "bar.__name__",bar.__name__


@use_logging
def foo():
    print "i am foo"
print foo()
print "foo.__name__",foo.__name__

from functools import wraps
def logged(func):
    @wraps(func)
    def with_logging(*args,**kwargs):
        print func.__name__ + " was called"
        return func(*args,**kwargs)
    return with_logging

@logged
def f(x):
    return x+x*x

print f(1)
print "f.__name__",f.__name__


==============
     结果
==============


i am bar
WARNING:root:bar in running
None
WARNING:root:foo in running #解决调用函数时想使用额外的附加条件时的复用问题
bar.__name__ wrapper #解决函数属性发生改变的问题
i am foo
None
foo.__name__ wrapper #解决函数属性发生改变的问题
f was called #解决调用函数时想使用额外的附加条件时的复用问题
2
f.__name__ f #解决函数属性发生改变的问题

参考https://www.zhihu.com/question/26930016

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值