鱼C论坛

 找回密码
 立即注册
查看: 484|回复: 5

[已解决]关于小甲鱼讲的函数装饰器

[复制链接]
发表于 2024-4-4 19:55:48 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
def use_test2(a):
    def inuse_test2():
        print("usetest开始:")
        start=time.time()
        a()
        print("usetest结束")
        stop=time.time()
        print(f"花费{(stop-start):.2f}秒")
    return inuse_test2()
@use_test
def test2():
    print("Star Platinum,The World!")
    time.sleep(5)
test2()
我根据小甲鱼讲的装饰器那一课打了这串代码,但是在最后调用test2()的时候报错了:
TypeError: 'NoneType' object is not callable
请问有人知道怎么解决吗
最佳答案
2024-4-4 19:57:28
skyteam超级吕布 发表于 2024-04-04 19:57
没用唉,改了还是一样的报错


抱歉,我之前的回答有误导性。问题出在装饰器函数上,你需要将装饰器函数定义为一个装饰器,并将其应用到需要装饰的函数上。

这里是修复后的代码示例:
import time

def use_test2(a):
    def inuse_test2():
        print("usetest开始:")
        start = time.time()
        a()
        print("usetest结束")
        stop = time.time()
        print(f"花费{(stop-start):.2f}秒")
    return inuse_test2

@use_test2
def test2():
    print("Star Platinum, The World!")
    time.sleep(5)

test2()

运行这段代码,你会看到输出结果,并统计了函数执行的时间。

重要的一点是,装饰器函数 `use_test2()` 返回的是函数对象 `inuse_test2`,而不是调用该函数。这样,在使用装饰器时才能正确地将其应用到被装饰的函数上。

希望这次能帮到你!

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2024-4-4 19:55:59 | 显示全部楼层
你好,通过查看你的代码发现问题出在装饰器函数中的最后一行。将`return inuse_test2()`改为`return inuse_test2`即可解决问题。

修改后的代码如下:
import time

def use_test2(a):
    def inuse_test2():
        print("usetest开始:")
        start=time.time()
        a()
        print("usetest结束")
        stop=time.time()
        print(f"花费{(stop-start):.2f}秒")
    return inuse_test2

@use_test2
def test2():
    print("Star Platinum,The World!")
    time.sleep(5)

test2()

运行这段代码,你会看到正确的输出结果。希望能帮到你!

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2024-4-4 19:57:16 | 显示全部楼层
FishC 发表于 2024-4-4 19:55
你好,通过查看你的代码发现问题出在装饰器函数中的最后一行。将`return inuse_test2()`改为`return inuse_ ...

没用唉,改了还是一样的报错
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2024-4-4 19:57:28 | 显示全部楼层    本楼为最佳答案   
skyteam超级吕布 发表于 2024-04-04 19:57
没用唉,改了还是一样的报错


抱歉,我之前的回答有误导性。问题出在装饰器函数上,你需要将装饰器函数定义为一个装饰器,并将其应用到需要装饰的函数上。

这里是修复后的代码示例:
import time

def use_test2(a):
    def inuse_test2():
        print("usetest开始:")
        start = time.time()
        a()
        print("usetest结束")
        stop = time.time()
        print(f"花费{(stop-start):.2f}秒")
    return inuse_test2

@use_test2
def test2():
    print("Star Platinum, The World!")
    time.sleep(5)

test2()

运行这段代码,你会看到输出结果,并统计了函数执行的时间。

重要的一点是,装饰器函数 `use_test2()` 返回的是函数对象 `inuse_test2`,而不是调用该函数。这样,在使用装饰器时才能正确地将其应用到被装饰的函数上。

希望这次能帮到你!

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2024-4-4 20:02:49 | 显示全部楼层
FishC 发表于 2024-4-4 19:57
抱歉,我之前的回答有误导性。问题出在装饰器函数上,你需要将装饰器函数定义为一个装饰器,并将其应用 ...

ok没报错了谢谢
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2024-4-4 20:02:59 | 显示全部楼层


不客气,很高兴能帮到你!如果有任何其他问题,请随时向我提问。祝你编程学习顺利,再见!

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-12-28 14:46

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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