start = time.time()
func()
stop = time.time()
这段中的func()搞不懂是什么意思。
上下面都见到def func()
无言之梦 发表于 2022-9-1 15:45
装饰器第一部分的闭包过程中不打 return call_func为什么报错
应该是使用return才会执行call_func中的内容。当然不使用return可以直接用call_func()代替。
个人理解。不知道对不对 不使用装饰器的话,funA和msg可以同时传入外层函数,可以少嵌套一层 七钱五 发表于 2022-10-16 16:47
测试函数不能带参数,不然会报错,这是为什么呢?比如只能funA(),而不能是funA(x)
可以带参数,参数要放在内部的嵌套函数中传递哦~
def dec(func):
def call_func(x, y):
print(f"装饰器来过,x = {x}, y = {y}")
return call_func
@dec
def test(x, y):
pass
test(3, 4) Loafer0 发表于 2022-11-25 20:51
我也遇到了同样的问题,想知道后面怎么解决了?
可以带参数,详见 #28 楼回复~ import time
def time_master(): #将func拿到内层#
def call_func(func): #这么写为什么会报错,不懂,求解#
print("开始运行程序...")
start = time.time()
func()
stop = time.time()
print("结束程序运行...")
print(f"一共耗费了 {(stop-start):.2f} 秒。")
return call_func
def myfunc():
time.sleep(2)
print("I love FishC.")
myfunc = time_master(myfunc)
myfunc() 看不出哪里有问题,报错了import time
def time_master(func):
def call_func():
print("程序开始运行...")
start = time.time()
func()
stop = time.time()
print("程序运行结束...")
print(f"一共运行了{(stop - start).2f}秒。")
return call_func
@time_master
def myfunc():
time.sleep
print("Hello,FishC!")
myfunc()
同舟 发表于 2023-1-4 09:39
这段中的func()搞不懂是什么意思。
上下面都见到def func()
定义中def time_master(func):里面有,相当于形参吧,下面定义中的myfunc相当于实参,个人理解。 import time ,random
def time_master(fun):
def cu():
print("程序开始")
start = time.time()
fun()
print("程序结束")
end = time.time()
print("程序共运行了%.2f秒"%(end-start))
return cu
@time
KeyboardInterrupt
@time_master()
def test():
time.sleep(random.randrange(1,5))
print("welcome to FishC.com")
FengHL 发表于 2023-4-14 23:08
看不出哪里有问题,报错了
格式化字符串里面没加冒号 多层可以理解成递归里面不断向下调用 @classmethod
def funA()
等价于
>>>funA = classmethod(funA)
>>>funA() def login(level):
print("ff")
def fun2(func):
def fun3():
func()
return fun3
return fun2
@login(level = 1)
def funA():
print("gg")
ff
为什么在第一个和第二个函数之间加一句输出后,写完语法糖直接就输出了,而去掉那句print就会正常 有点没懂为啥视频那个例子结果是65,即便是从下往上,它会记住X的值吗,为啥呢,没理解{:10_254:} 本帖最后由 涉水鱼 于 2023-12-20 16:36 编辑
好难{:10_269:}
请问为什么装饰器函数一定要是闭包函数呢?
如果装饰器不是闭包函数:
def call_time(func):
start=
func()
stop=
return print()
@call_time
def myfunc():
然后把设定改为加在myfunc()函数上的@call-time语法糖的实际意思是myfunc()=call_time(func),感觉好像也不影响使用,这是为什么呢,搞不太清楚
{:10_266:} fishcyou 发表于 2022-5-2 19:01
装饰器可以实现在不修改原来代码的前提下增加新功能。
(通过将原来代码作为函数,传入装饰器,返回新的 ...
这里的(msg='A')不理解,为什么要给logger函数的msg参数赋值为‘A’呢?
页:
1
[2]