鱼C论坛

 找回密码
 立即注册
12
返回列表 发新帖
楼主: 小甲鱼

[知识点备忘] 第046讲:函数(VI)- 装饰器

[复制链接]
发表于 2023-1-4 09:39:23 | 显示全部楼层
def call_func():
            start = time.time()
            func()
            stop = time.time()
这段中的func()搞不懂是什么意思。
上下面都见到def func()
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 0 反对 1

使用道具 举报

发表于 2023-1-15 21:11:40 | 显示全部楼层
无言之梦 发表于 2022-9-1 15:45
装饰器第一部分的闭包过程中不打 return call_func  为什么报错

应该是使用return才会执行call_func中的内容。当然不使用return可以直接用call_func()代替。
个人理解。不知道对不对
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-1-31 21:18:35 | 显示全部楼层
不使用装饰器的话,funA和msg可以同时传入外层函数,可以少嵌套一层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2023-3-25 03:49:03 | 显示全部楼层
七钱五 发表于 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)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2023-3-25 03:49:56 | 显示全部楼层
Loafer0 发表于 2022-11-25 20:51
我也遇到了同样的问题,想知道后面怎么解决了?

可以带参数,详见 #28 楼回复~
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-3-26 20:51:57 | 显示全部楼层
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()
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-4-14 23:08:40 | 显示全部楼层
看不出哪里有问题,报错了
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()
报错.PNG
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-4-16 10:50:43 | 显示全部楼层
同舟 发表于 2023-1-4 09:39
这段中的func()搞不懂是什么意思。
上下面都见到def func()

定义中
def time_master(func):
里面有,相当于形参吧,下面定义中的myfunc相当于实参,个人理解。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-4-20 09:44:44 | 显示全部楼层
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")
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-9-12 16:28:28 | 显示全部楼层
FengHL 发表于 2023-4-14 23:08
看不出哪里有问题,报错了

格式化字符串里面没加冒号
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-9-22 15:49:35 | 显示全部楼层
多层可以理解成递归里面不断向下调用
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-10-7 20:12:57 | 显示全部楼层
@classmethod
def funA()

等价于
>>>funA = classmethod(funA)
>>>funA()
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-11-2 22:08:23 | 显示全部楼层
def login(level):
    print("ff")
    def fun2(func):
        def fun3():
            func()
        return fun3
    return fun2

@login(level = 1)
def funA():
    print("gg")

   
ff
为什么在第一个和第二个函数之间加一句输出后,写完语法糖直接就输出了,而去掉那句print就会正常
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-12-13 10:55:06 | 显示全部楼层
有点没懂为啥视频那个例子结果是65,即便是从下往上,它会记住X的值吗,为啥呢,没理解
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-12-20 11:52:19 | 显示全部楼层
本帖最后由 涉水鱼 于 2023-12-20 16:36 编辑

好难
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2024-1-10 08:27:41 | 显示全部楼层
请问为什么装饰器函数一定要是闭包函数呢?
如果装饰器不是闭包函数:
def call_time(func):
    start=
    func()
    stop=
    return print()

@call_time
def myfunc():

然后把设定改为加在myfunc()函数上的@call-time语法糖的实际意思是myfunc()=call_time(func),感觉好像也不影响使用,这是为什么呢,搞不太清楚
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2024-3-23 10:47:18 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2024-7-2 12:23:38 | 显示全部楼层
fishcyou 发表于 2022-5-2 19:01
装饰器可以实现在不修改原来代码的前提下增加新功能。

(通过将原来代码作为函数,传入装饰器,返回新的 ...

这里的(msg='A')不理解,为什么要给logger函数的msg参数赋值为‘A’呢?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-12-22 16:58

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表