热门IT资讯网

Python 闭包函数

发表于:2024-11-30 作者:热门IT资讯网编辑
编辑最后更新 2024年11月30日,闭包函数:闭:指的是定义在函数内部的函数比如手机是闭包函数(内层函数),被手机包装盒 (外层函数) 包裹起来,手机可以使用包装盒中的东西,内层函数可以引用外层函数的名字。闭包函数:定义在函数内部的函数

  闭包函数:

  闭:指的是定义在函数内部的函数

  比如手机是闭包函数(内层函数),被手机包装盒 (外层函数) 包裹起来,

  手机可以使用包装盒中的东西,内层函数可以引用外层函数的名字。

  闭包函数:定义在函数内部的函数,并且该函数包含对外部函数作用域中名字的引用,该函数就称为闭包函数。

  注意:该函数的作用域在定义阶段就定义死了,与调用位置无关

  闭包函数是 函数嵌套、函数对象、名称空间与作用域 结合体。

  基本形式:

  def outer():

  name ='egon'

  def inner():

  print('my name is %s' %name)

  return inner

  # print(outer())

  f=outer()

  f()

  闭包的小应用:

  #爬虫:模拟访问百度

  import requests

  def 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():郑州妇科医院 http://www.zyfuke.com/

  response = requests.get(url)

  if response.status_code == 200:

  print(response.text)

  return get

  baidu = outter() #baidu --->get

  baidu()

  # 改进:

  def outter(url):

  def get():

  response = requests.get(url)

  if response.status_code == 200:

  print(response.text)

  return get

  baidu = outter('https://www.baidu.com/') #baidu --->get

  taobao = outter('https://www.taobao.com/') #taobao --->get

  baidu() #专门调百度

  taobao() #专门调淘宝


0