鱼C论坛

 找回密码
 立即注册
查看: 2259|回复: 1

关于函数修饰器的疑惑

[复制链接]
发表于 2017-8-29 16:10:56 | 显示全部楼层 |阅读模式

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

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

x
  1. import time

  2. def timeslong(func):
  3.    
  4.     start = time.clock()
  5.     print("It's time starting ! ")
  6.     func()
  7.     print("It's time ending ! ")
  8.     end = time.clock()
  9.     return "It's used : %s ." % (end - start)
  10.    

  11. @timeslong
  12. def f():
  13.     y = 0
  14.     for i in range(10):
  15.         y = y + i + 1
  16.         print(y)
  17.     return y
复制代码


timeslong(f)
It's time starting !
Traceback (most recent call last):

  File "<ipython-input-99-f960a7b5bba5>", line 1, in <module>
    timeslong(f)

  File "D:/py练习/sex_38.py", line 39, in timeslong
    func()

TypeError: 'str' object is not callable

如上述代码所示,为什么会报错啊,正确的运行方式应该是什么?
直接运行f()可以得出结果,可是这里的f不是应该作为参数传给timeslong了嘛,应该运行timeslong函数才对,不是很明白
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2017-8-29 16:39:18 | 显示全部楼层
  1. import time


  2. def timeslong(func):
  3.     def inner():
  4.         start = time.clock()
  5.         print("It's time starting ! ")
  6.         func()
  7.         print("It's time ending ! ")
  8.         end = time.clock()
  9.         return "It's used : %s ." % (end - start)
  10.     return inner


  11. @timeslong
  12. def f():
  13.     y = 0
  14.     for i in range(10):
  15.         y += i + 1
  16.         print(y)
  17.     return y

  18. result = f()
  19. print(result)
复制代码

装饰的时候f已经不是函数了,而是"It's used : %s ." % (end - start)这个字符串
f()字符串f是不可调用的
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-12-23 13:35

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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