1.三元运算
if条件成立的结果 if 条件 else 条件不成立的结果
例如:
a=20
b=10
c=a if a>b else b
print(c)
2.命名空间
- 全局命名空间:创建的存储“变量名与值的关系”的空间叫做全局命名空间
- 局部命名空间:在函数的运行中开辟的临时的空间叫做局部命名空间
- 内置命名空间:内置命名空间中存放了python解释器为我们提供的名字:input,print,str,list,tuple...它们都是我们熟悉的,拿过来就可以用的方法。
三种命名空间之间的加载顺序和取值顺序:
加载顺序:内置(程序运行前加载)-->全局(从上到下顺序加载进来的)-->局部(调用的时候加载)--->内置
取值:在局部调用:局部命名空间--->全局命名空间--->内置命名空间
站在全局范围找:全局----内置----局部
使用:
全局不能使用局部的
局部的可以使用全局的
3.作用域:就是作用范围
1.命名空间和作用域是分不开的
2.作用域分为两种:
全局作用域:全局命名空间与内置命名空间的名字都属于全局范围
在整个文件的任意位置都能被引用,全局有效
局部作用域:局部命名空间,只能在局部范围内生效
3.站在全局看:
使用名字的时候:如果全局有,用全局的
如果全局没有,用内置的
4.为什么要有作用域?
为了函数内的变量不会影响到全局
5.globals方法:查看全局作用域的名字【print(globals())】
locals方法:查看局部作用域的名字【print(locals())】
1 def func(): 2 a = 12 3 b = 20 4 print(locals()) 5 print(globals()) 6 7 func()
站在全局看,globals is locals
global关键字:强制转换为全局变量
1 # x=1 2 # def foo(): 3 # global x #强制转换x为全局变量 4 # x=10000000000 5 # print(x) 6 # foo() 7 # print(x) 8 # 这个方法尽量能少用就少用
nonlocal让内部函数中的变量在上一层函数中生效,外部必须有
1 # x=1 2 # def f1(): 3 # x=2 4 # def f2(): 5 # # x=3 6 # def f3(): 7 # # global x#修改全局的 8 # nonlocal x#修改局部的(当用nonlocal时,修改x=3为x=100000000,当x=3不存在时,修改x=2为100000000 ) 9 # # 必须在函数内部 10 # x=10000000000 11 # f3() 12 # print(‘f2内的打印‘,x) 13 # f2() 14 # print(‘f1内的打印‘, x) 15 # f1() 16 # # print(x)
4.函数的嵌套定义
1 def animal(): 2 def tiger(): 3 print(‘nark‘) 4 print(‘eat‘) 5 tiger() 6 animal()
5.作用域链
1 x=1 2 def heihei(): 3 x=‘h‘ 4 def inner(): 5 x=‘il‘ 6 def inner2(): 7 print(x) 8 inner2() 9 inner() 10 heihei()
6.函数名的本质:就是函数的内存地址
1 def func(): 2 print(‘func‘) 3 print(func)#指向了函数的内存地址
7.函数名可以用做函数的参数
1 def func(): 2 print(‘func‘) 3 4 def func2(f): 5 f() 6 print(‘func2‘) 7 func2(func)
函数名可以作为函数的返回值
return说明1
def func(): def func2(): print(‘func2‘) return func2 f2=func() f2() #func2=func() #func2()
2.
def f1(x):
print(x)
return ‘123‘
def f2():
ret = f1(‘s‘) #f2调用f1函数
print(ret)
f2()
3.
def func():
def func2():
return ‘a‘
return func2 #函数名作为返回值
func2=func()
print(func2())
8.闭包:
闭包:1.闭 :内部的函数
2.包 :包含了对外部函数作用域中变量的引用
def hei():
x=20
def inner():
x=10 #如果x定义了,他就用自己的了,就实现不了闭包
print(x)
1 # 闭包的常用形式: 2 def hei(): 3 x=20 4 def inner(): 5 ‘‘‘闭包函数‘‘‘ 6 print(x) 7 return inner()
判断闭包函数的方法:__closure__
1 #输出的__closure__有cell元素 :是闭包函数 2 def func(): 3 name = ‘eva‘ 4 def inner(): 5 print(name) 6 print(inner.__closure__) 7 return inner 8 9 f = func() 10 f() 11 12 13 #输出的__closure__为None :不是闭包函数 14 name = ‘egon‘ 15 def func2(): 16 def inner(): 17 print(name) 18 print(inner.__closure__) 19 return inner 20 21 f2 = func2() 22 f2()
闭包获取网络应用
1 # from urllib.request import urlopen 2 # def index(url): 3 # def inner(): 4 # return urlopen(url).read() 5 # return inner 6 # u=‘http://www.cnblogs.com/Eva-J/articles/7156261.html#_label1‘ 7 # get = index(u) 8 # print(get())
9.总结
作用域:小范围的可以用大范围的,但是大范围的不能用小范围的
范围从大到小(图)
如果在小范围内,如果要用一个变量,是当前这个小范围有的,就用自己的
如果在小范围内没有,就用上一级的,上一级没有的,就用上上级的,以此类推
如果都没有,报错
10.思维导图