Python---闭包、函数作为参数传递、装饰器-----进阶必备,不必再为弄不清而烦恼

简介: Python---闭包、函数作为参数传递、装饰器-----进阶必备,不必再为弄不清而烦恼

都说Python装饰器好用,那么Python 装饰器是什么呢?下面让我们来解开它的神秘面试,深层次的了解并学会使用吧! 首先Python装饰器(fuctional decorators)就是用于拓展原来函数功能的一种函数,目的是在不改变原函数名(或类名)的情况下,给函数增加新的功能。

这个函数的特殊之处在于它的返回值也是一个函数,这个函数是内嵌“原“”函数的函数。


**

什么是闭包

**

#  闭包
def fun1():
    name="想学"
    def fun2():
        print(name)
    fun2()
fun1()

结果

想学

我们可以发现函数的返回值是一个函数。

执行过程:fun1()==>name="想学"==>def fun2()[此处此时没有调用]==》fun2()==>print(name)

我们可以发现在没有改变fun1()函数函数名的情况下使函数fun1()增加了新的功能。


**

通过time去测试一个函数去测试另一个函数执行时间

**

time包


time包中用且此时需要用到的我觉得就那么几个方法

First time.time,就是得到此时的时间,传给一个变量保存,一般用于程序执行时长测试,在程序开始和结束都写入time.time,记录下开始和结束时间,最后做一下差就可以得到程序的运行时长。


Second: time.sleep(时间),是程序执行到time.sleep时睡眠(休息)一会再执行后面的程序。通常用于对抗爬虫中的反爬,也可以处理一些极端情况,例如程序执行时间太短无法打印出时长,我们就会通过time.sleep使时长延长,打印出时间,下面会说例子进行讲解。


import time
def fun():
    print("我是被测试函数")
#开始运行时间
start_time=time.time()
#结束运行时间
end_time=time.time()
#计算总共用时
print("--->总运行时间:%s--->"%(end_time-start_time))

结果:

--->总运行时间:0.0--->

唉,怎么回事,程序执行的时长为0,难道程序没执行???

事实当然不是这样,只是程序很简单,电脑执行过快没有显示,仅此而已

下面加入了time.sleep(0.1),程序休眠0.1秒,再让我们看看结果吧。

# 写一个函数去测试另一个函数的效率
# 首先引入时间库  time
import time
def fun():
    print("我是被测试函数")
#开始运行时间
start_time=time.time()
# print(start_time)
#暂停0.1s
time.sleep(0.1)
#结束运行时间
end_time=time.time()
#计算总共用时
print("--->总运行时间:%s--->"%(end_time-start_time))

结果:

--->总运行时间:0.11335253715515137--->

我们可以发现程序执行时长为**0.11335253715515137**,大于0.1,所以可以证明上面的代码是运行了的,只不过执行太快。姑且认为是是电脑没有捕捉到吧

**

函数作为参数传入另一个函数

**

众所周知python中的函数可以作为参数传入的,但是要把括号去掉,不然基本上都包**TypeError: 'NoneType' object is not callable**错误。


下面让我们来看看怎么作为参数传递的,又是怎么测出程序运行的时间的

#把运行时间放入函数内
import time
def fun3():
    print("hhhhhh")
def timer(fn):
    start_time=time.time()
    time.sleep(0.1)
    fn()
    end_time=time.time()
    print("--->总运行时间:%s--->" % (end_time - start_time))
fun3()
f1=fun3   #作为函数赋值给其他变量
fun3=timer
fun3(f1)

结果:

hhhhhh
hhhhhh
--->总运行时间:0.10659313201904297--->

第一个hhhhh是fun3()打印出来的,因为在下面调用了上面的fun3()函数,打印出来一个hhhhhh。然后f1=fun3 ,此时fun3作为函数赋值给其他变量,fun3就是fun3(),因为传参时候要去掉括号,所以f1=fun3,此时打印下f1也可以打印出hhhhhh,因为fun3()最为值赋值给了f1。timer赋值给func,然后func(f1)就出现上面的结果了。

简而言之fun3(f1)就是 timer(fun3()),只不过是吧两个函数都当作两个变量赋值给了变量。

f1=fun3   #作为函数赋值给其他变量
fun3=timer
fun3(f1)

等价于

f1=fun3
timer(f1)

同样物品们用time.time记录下来了项目的开始时间和结束时间。使用time.slepp(0.1)睡眠了0.1秒,毕竟这个程序还是非常简单的,电脑执行起来还是非常快的

**

非装饰器实现函数功能

**


#  非装饰器
import time
def timer(f):   #boss
    def inner():   #boss2
        start_time=time.time()
        time.sleep(0.1)
        f()
        end_time = time.time()
        print("--->总运行时间:%s--->" % (end_time - start_time))
    return inner
def func():   #rss
    print("这里是func")
A=timer(func)
A()

结果:

这里是func
--->总运行时间:0.11059880256652832--->

A=timer(func) ,func函数作为参数传入timer中,然后赋值给A,最后要叫一下A()


叫一下是什么意思呢??例如:

def k():
    print("你好,世界")
k()

以上所示,再写好一个函数之后,在下面要叫一下(也就是调用一下,不然你打印出来 print(k)就是一串**<function k at 0x000001F490B1D1F0>**,目测应该是一串类似于地址的数值,可能就是地址)****


**

语法糖/装饰器

**

什么是语法糖,什么又是装饰器呢,学完你就会发现语法糖其实就是装饰器,就问你,懵不懵。

#语法糖/装饰器
import time
def timer(f):   #boss
    def inner():   #boss2
        start_time=time.time()
        time.sleep(0.1)
        f()
        end_time = time.time()
        print("--->总运行时间:%s--->" % (end_time - start_time))
    return inner
@timer #fun=timer(func)
def func():
    print("这里是func")
func()

结果:

这里是func
--->总运行时间:0.10718822479248047--->

我们可以发现修饰器和非修饰器的区别就在与非修饰器没有写fun=timer(func),而是直接在func上写一个@timer,两者是等价的。也就是修饰器从这两段来看只是省略了一句代码,但是你会慢慢的发现它的用处很大

**关注我,带你了解更多python知识**




目录
相关文章
|
1天前
|
开发者 Python
Python入门:8.Python中的函数
### 引言 在编写程序时,函数是一种强大的工具。它们可以将代码逻辑模块化,减少重复代码的编写,并提高程序的可读性和可维护性。无论是初学者还是资深开发者,深入理解函数的使用和设计都是编写高质量代码的基础。本文将从基础概念开始,逐步讲解 Python 中的函数及其高级特性。
Python入门:8.Python中的函数
|
1月前
|
存储 人工智能 Python
[oeasy]python061_如何接收输入_input函数_字符串_str_容器_ 输入输出
本文介绍了Python中如何使用`input()`函数接收用户输入。`input()`函数可以从标准输入流获取字符串,并将其赋值给变量。通过键盘输入的值可以实时赋予变量,实现动态输入。为了更好地理解其用法,文中通过实例演示了如何接收用户输入并存储在变量中,还介绍了`input()`函数的参数`prompt`,用于提供输入提示信息。最后总结了`input()`函数的核心功能及其应用场景。更多内容可参考蓝桥、GitHub和Gitee上的相关教程。
16 0
|
1月前
|
设计模式 前端开发 Shell
Python装饰器是什么?
装饰器是Python中用于动态修改函数、方法或类功能的工具,无需改变原代码。通过将函数作为参数传递并返回新函数,装饰器可以在原函数执行前后添加额外逻辑。例如,使用`@logger`装饰器可以打印函数调用日志,而`@timethis`则可用于计算函数执行时间。为了保持被装饰函数的元信息(如`__name__`和`__doc__`),可使用`functools.wraps`装饰器。此外,带参数的装饰器可通过嵌套函数实现,如`@timeitS(2)`,以根据参数条件输出特定信息。
90 59
|
1月前
|
测试技术 数据库 Python
Python装饰器实战:打造高效性能计时工具
在数据分析中,处理大规模数据时,分析代码性能至关重要。本文介绍如何使用Python装饰器实现性能计时工具,在不改变现有代码的基础上,方便快速地测试函数执行时间。该方法具有侵入性小、复用性强、灵活度高等优点,有助于快速发现性能瓶颈并优化代码。通过设置循环次数参数,可以更准确地评估函数的平均执行时间,提升开发效率。
106 61
Python装饰器实战:打造高效性能计时工具
|
1月前
|
Python
[oeasy]python057_如何删除print函数_dunder_builtins_系统内建模块
本文介绍了如何删除Python中的`print`函数,并探讨了系统内建模块`__builtins__`的作用。主要内容包括: 1. **回忆上次内容**:上次提到使用下划线避免命名冲突。 2. **双下划线变量**:解释了双下划线(如`__name__`、`__doc__`、`__builtins__`)是系统定义的标识符,具有特殊含义。
32 3
|
1月前
|
JSON 监控 安全
深入理解 Python 的 eval() 函数与空全局字典 {}
`eval()` 函数在 Python 中能将字符串解析为代码并执行,但伴随安全风险,尤其在处理不受信任的输入时。传递空全局字典 {} 可限制其访问内置对象,但仍存隐患。建议通过限制函数和变量、使用沙箱环境、避免复杂表达式、验证输入等提高安全性。更推荐使用 `ast.literal_eval()`、自定义解析器或 JSON 解析等替代方案,以确保代码安全性和可靠性。
45 2
|
2月前
|
缓存 数据安全/隐私保护 Python
python装饰器底层原理
Python装饰器是一个强大的工具,可以在不修改原始函数代码的情况下,动态地增加功能。理解装饰器的底层原理,包括函数是对象、闭包和高阶函数,可以帮助我们更好地使用和编写装饰器。无论是用于日志记录、权限验证还是缓存,装饰器都可以显著提高代码的可维护性和复用性。
50 5
|
2月前
|
数据可视化 DataX Python
Seaborn 教程-绘图函数
Seaborn 教程-绘图函数
87 8
|
2月前
|
存储 缓存 Python
Python中的装饰器深度解析与实践
在Python的世界里,装饰器如同一位神秘的魔法师,它拥有改变函数行为的能力。本文将揭开装饰器的神秘面纱,通过直观的代码示例,引导你理解其工作原理,并掌握如何在实际项目中灵活运用这一强大的工具。从基础到进阶,我们将一起探索装饰器的魅力所在。
|
2月前
|
Python
探索Python中的装饰器:简化代码,增强功能
在Python的世界里,装饰器就像是给函数穿上了一件神奇的外套,让它们拥有了超能力。本文将通过浅显易懂的语言和生动的比喻,带你了解装饰器的基本概念、使用方法以及它们如何让你的代码变得更加简洁高效。让我们一起揭开装饰器的神秘面纱,看看它是如何在不改变函数核心逻辑的情况下,为函数增添新功能的吧!

热门文章

最新文章

推荐镜像

更多