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.思维导图