<每日一题>题目3:编写装饰器,为多个函数加上记录调用功能,要求每次调用函数都将被调用的函数名称写入文件...

  

 1 def log(func):
 2     def inner(*args,**kwargs):
 3         with open('log',mode='a',encoding='utf-8') as f:    #以追加的方式打开
 4             f.write(func.__name__+'\n')     #写人调用函数的函数名,以\n结尾
 5         ret = func(*args,**kwargs)
 6         return ret
 7     return inner
 8 
 9 @log
10 def func_1():
11     print('执行一次func_1')
12 
13 @log
14 def func_2():
15     print('执行一次func_2')
16 
17 func_1()
18 func_2()
19 func_2()
20 func_2()
21 func_1()

运行结果:

1 执行一次func_1
2 执行一次func_2
3 执行一次func_2
4 执行一次func_2
5 执行一次func_1

log文件情况:

转载于:https://www.cnblogs.com/shuimohei/p/9680284.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值