不希望修改先有函数,又希望给该函数增加一些功能
9行,@log放在now()之前,执行now()时,实际为执行9行的@log
效果为now=log(now),第一个now为变量名,第二个now为10行的函数now()
所以这一步会生成一个名为now的变量,它的值为log函数return回的wrapper函数,wrapper函数可以调用外层函数传入的now()参数
所以现在的结果是now=trigger,所以14行now(),执行的就是传入了10行now函数的trigger函数
4行的return,是考虑如果now()有返回值的情况,可以将该值返回,就好像我们直接执行now()一样12行, 等效于
now=log('dddd')(now)现在打印now.__name__,显示wrapper,因为实际我们调用的是wrapper函数
现在需要将now.__name__赋值给wrapper.__name__
有专门的模块解决这个问题from functools import wraps,引入functools模块中的wraps函数@wraps(func)加在wrapper函数前面
相关文章: