发布于2019-08-07 18:23 阅读(533) 评论(0) 点赞(1) 收藏(2)
他们是为其他函数的新增功能的函数
函数即变量
嵌套函数 :
定义: 在一个函数中定义另一个函数:
def hi(name="faily"):
print("now you are inside the hi() function")
def greet():
return "now you are in the greet() function"
def welcome():
return "now you are in the welcome() function"
print(greet())
print(welcome())
print("now you are back in the hi() function")
if __name__ == "__main__":
hi()
从函数中返回函数
其实并不需要在一个函数里去执行另一个函数,也可以将其作为输出返回出来
def hi(name="faily"):
def greet():
return "now you are in the greet() function"
def welcome():
return "now you are in the welcome() function"
if name == "faily":
return greet
else:
return welcome
if __name__ == "__main__"
a = hi() # 此时返回的a实际是greet函数名
print(a) # 执行greet函数
在if/else
语句中我们返回greet
和welcome
,而不是greet()
和welcome()
。为什么那样?这是因为当你把一对小括号放在后面,这个函数就会执行;然而如果你不放括号在它后面,那它可以被到处传递,并且可以赋值给别的变量而不去执行它。
当我们写下
a = hi()
,hi()
会被执行,而由于name
参数默认是yasoob,所以函数greet
被返回了。如果我们把语句改为a = hi(name = "momo")
,那么welcome
函数将被返回。我们还可以打印出hi()()
,这会输出now you are in the greet() function。
高阶函数
定义: 把一个函数名当作实参传递给另外一个函数
# 计算函数的bar运行时间
import time
def bar():
time.sleep(3)
print("in the bar")
def run_time(func):
t1 = time.time()
func()
t2 = time.time()
print("the func:{0} run time is {1}".format(func.__name__,t2-t1))
if __name__ == "__main__":
run_time(bar)
缺点: 虽然实现了此功能,但是改变了 bar
函数名
实际就是: 高阶函数
+嵌套函数
的结合体
认证 装饰器演变
v1 将函数作为参数传递进 嵌套函数中, 返回函数本身
def cert_decorator(func):
def wrapTheFunction():
user = input("pls input password:").strip()
if user == "faily":
print("---welcome login----")
func()
else:
print("----wrong password")
return wrapper
def task():
print("do somthing ")
if __name__ == "__main__":
task = cert_decorator(task) # 执行装饰器函数,将task作为参数传递,赋值给task变量,返回的是wrapper函数名,内部函数func并没有执行
task() # 执行task,实际就是执行了wrapper(),然后执行了内部的func()函数
实现了不改变函数名的和内部结构的前提下, 实现了认证,但是, 但是... 用户需要多些一行重命名函数变量的方式
v2 python内部可以通过@
符号进行直接调用
def cert_decorator(func):
def wrapTheFunction():
user = input("pls input password:").strip()
if user == "faily":
print("---welcome login----")
func()
else:
print("----wrong password")
return wrapTheFunction
@cert_decorator
def task():
print("do somthing ")
if __name__ == "__main__":
task()
※ 好像我们大功告成了... 别高兴得太早 ,如果我们运行一下这行代码 会存在一个问题
print(task.__name__)
#output
wrapTheFunction
♥ . 这并不是我们想要的!Ouput输出应该是task
。这里的函数被warpTheFunction替代了。它重写了我们函数的名字和注释文档(docstring), 如果我们想在被装饰的函数在执行之前去访问函数的某些属性(文档, 变量名...),显然是没办法做到的, 怎么办???
幸运的是Python提供给我们一个简单的函数来解决这个问题,那就是functools.wraps
。我们修改上一个例子来使用functools.wraps
v3 使用functools.wraps
from functools import wraps
def cert_decorator(func):
@wraps(func)
def wrapTheFunction():
user = input("pls input password:").strip()
if user == "faily":
print("---welcome login----")
func()
else:
print("----wrong password----")
return wrapTheFunction
@cert_decorator
def task():
print("do somthing ")
if __name__ == "__main__":
task()
print(task.__name__)
# output
pls input password:mm
----wrong password----
task
注意:@wraps接受一个函数来进行装饰,并加入了复制函数名称、注释文档、参数列表等等的功能。这可以让我们在装饰器里面访问在装饰之前的函数的属性。
作者:好难受
链接:https://www.pythonheidong.com/blog/article/12060/e5cb2f582518fe45e482/
来源:python黑洞网
任何形式的转载都请注明出处,如有侵权 一经发现 必将追究其法律责任
昵称:
评论内容:(最多支持255个字符)
---无人问津也好,技不如人也罢,你都要试着安静下来,去做自己该做的事,而不是让内心的烦躁、焦虑,坏掉你本来就不多的热情和定力
Copyright © 2018-2021 python黑洞网 All Rights Reserved 版权所有,并保留所有权利。 京ICP备18063182号-1
投诉与举报,广告合作请联系vgs_info@163.com或QQ3083709327
免责声明:网站文章均由用户上传,仅供读者学习交流使用,禁止用做商业用途。若文章涉及色情,反动,侵权等违法信息,请向我们举报,一经核实我们会立即删除!