本篇内容主要讲解“Python闭包函数的用法”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Python闭包函数的用法”吧!
简而言之, 闭包的特点就是内部函数引用了外部函数中的变量。 在Python中,支持将函数当做对象使用,也就是可以将一个函数当做普通变量一样用作另一个函数的参数和返回值。拥有此类特性的语言,一般都支持闭包。在一些语言中,在函数中可以(嵌套)定义另一个函数时,如果内部的函数引用了外部的函数的变量,则可能产生闭包。闭包可以用来在一个函数与一组“私有”变量之间创建关联关系。在给定函数被多次调用的过程中,这些私有变量能够保持其持久性。
闭包中被内部函数引用的变量,不会因为外部函数结束而被释放掉,而是一直存在内存中,知道内部函数被调用结束。
闭包函数
闭:指的是定义在函数内部的函数
比如手机是闭包函数(内层函数),被手机包装盒 (外层函数) 包裹起来,
手机可以使用包装盒中的东西,内层函数可以引用外层函数的名字。
闭包函数是 函数嵌套、函数对象、名称空间与作用域 结合体。
基本形式:
def outer():name ='egon'def inner():print('my name is %s' %name)return inner# print(outer())f=outer()f()
闭包的小应用:
#爬虫:模拟访问百度import requestsdef get(url):response = requests.get(url)if response.status_code == 200:print(response.text)get('https://www.baidu.com/')get('https://www.baidu.com/')get('https://www.baidu.com/') #问题:每次访问百度,都要调用一次,填一次地址# 解决办法:用闭包函数def outter():url = 'https://www.baidu.com/' #问题:把地址定死了,def get():response = requests.get(url)if response.status_code == 200:print(response.text)return getbaidu = outter() #baidu --->getbaidu()# 改进:def outter(url):def get():response = requests.get(url)if response.status_code == 200:print(response.text)return getbaidu = outter('https://www.baidu.com/') #baidu --->gettaobao = outter('https://www.taobao.com/') #taobao --->getbaidu() #专门调百度taobao() #专门调淘宝
到此,相信大家对“Python闭包函数的用法”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!