Python全栈自动化系列之Python编程基础(函数的作用域、内置函数)

  一、函数的作用域

 

 

全局变量:直接定义在模块中,在该模块的任何地方都可以直接使用

 

局部变量:定义在函数内部的变量,只能在定义的这个函数内部使用

 

note:模块,以.py结尾的文件,可以把它叫做模块

注意点:尽量不要在函数内部定义与全局变量同名的变量;如果必须要定义一个同名的变量,那么建议放在函数的最前面

 

 

  ****全局变量以及局部变量的理解***********
  # 全局变量
  name = "zl"
  def func():
    # 局部变量
    a = 100
    # 函数内部使用
    print(a)
    # 函数内部使用全局变量
    print(name)

  func()
  # 全局变量可以用
  print(name)

运行结果:

 

 

 二、在函数中使用关键字global,来声明变量,操作后可以对全局生效

  a = 100
  b = 200
  def func1():
    global a, b   # global声明摸个变量之后,那么这个变量在函数内部进行操作会对全局变量生效

    # 局部变量
    a = 999
    b = 789
    print("函数内打印a:",a)

  func1()
  print("函数外打印a:",a)
  print("函数外打印b:",b)

 

 

运行结果:

 

 

 三、高级内置函数

1)enumerate:利用他可以同时获取索引以及值

  li = [11,22,331,21,322]

  res = enumerate(li)
  for i in res:
    print(i)

运行结果:

 

 

 2)eval:识别字符串中有效的python表达式

  str1 = '{"a":11,"b":22}'
  str2 = "[11,22,33,44]"
  # 把str1转换为字典
  dic1 = eval(str1) # 相当于----->dic1 = {"a":11,"b":22}
  print(dic1,type(dic1))
  # 把str2转换成列表
  li = eval(str2)
  print(li,type(li))

运行结果:

 

 

 3)zip :聚合打包,列表元素长短不一时,以最短的为基准

注意点:zip打包返回的数据,只能使用一次

  li = [1,2,3,4]
  li2 = [11,22,33,44,55]
  li3 = [111,222,333,444,555,666,777]
  res = zip(li,li2,li3)
  print(list(res))

运行结果:

 

 

 zip打包返回的数据,只能使用一次

  # 转换成字典
  title = ["aa","bb","cc"]
  value = [11,22,33]
  res = zip(title,value)
  print(dict(res))
  print(list(res))  # 注意点:zip打包返回的数据,只能使用一次

运行结果:

 

 

4)filter:过滤器(根据第二个参数来决定是否把函数中的数据过滤出来)

有两个参数:第一个参数,函数;第二个参数,可迭代对象(iterable)

注意:iterable:可迭代对象

  简单理解,就是可以使用for循环遍历的都是可迭代对象,例如,字符串、列表、字典、集合、以及range所创建的数据

过滤的原理:filter会将第二个参数中的数据,进行遍历,然后当成参数传入给第一个参数(即函数中),根据函数返回的结果说否为True,来决定是否把数据过滤出来

例如:

 

def func(a):
print("这个是传入的参数a:",a)
# 通过写过滤的条件
return a>100 # 过滤大于100的数 (返回过滤)

li = [11,22,33,44,111,222,333]

res = filter(func,li)
print("返回过滤后的数据为:",list(res))

 

运行结果:

posted @ 2020-01-12 20:14  ZL蓝色海洋  阅读(187)  评论(0编辑  收藏  举报