关键字参数,名称空间和作用域
1. 命名关键字参数
在定义函数时,*后定义的参数,如下所示,称之为命名关键字参数
1.1特点:
命名关键字实参必须按照key=value的形式为其传值
def func(x,y,*,a,b): # 其中,a和b称之为命名关键字参数
print(x,y)
print(a,b)
func(1,2,b=222,a=111)
示例
def func(x,y,*,a=11111,b):
print(x,y)
print(a,b)
func(1,2,b=22222)
1.2 组合使用
1.2.1 形参混用的顺序:
位置新参,默认形参,*args,命名关键字形参,**kwargs
def func(x,y=111,*args,z,**kwargs):
print(x)
print(y)
print(args)
print(z)
print(kwargs)
1.2.2 实参混用的顺序:
def func(x,y,z,a,b,c):
print(x)
print(y)
print(z)
print(a)
print(b)
print(c)
func(111,y=222,*[333,444],**{'b':555,'c':666})
# 111,y=222,333,444,b=555,c=666,位置不对应
func(111,*[333,444],a=222,**{'b':555,'c':666})
# 111,333,444,a=222,b=555,c=666
func(111,*[333,444],**{'b':555,'c':666},a=222,)
# 111,3333,4444,b=555,c=666,a=222
2. 名称空间(namespace)
名称空间是对栈区的划分,存放名字的地方.有了名称空间之后,就可以在栈区中存放相同的名字
2.1 内置名称空间
存放的名字:
存放的python解释器内置的名字
存活周期:
python解释器启动则产生,python解释器关闭则销毁
>>> print
<built-in function print>
>>> input
<built-in function input>
2.2 全局名称空间
存放的名字:
只要不是函数内定义、也不是内置的,剩下的都是全局名称空间的名字
存活周期:
python文件执行则产生,python文件运行完毕后销毁
import os
x=10
if 13 > 3:
y=20
if 3 == 3:
z=30
# func=函数的内存地址
def func():
pass
class Foo:
pass
2.3 局部名称空间
存放的名字:
在调用函数时,运行函数体代码过程中产生的函数内的名字
存活周期:
在调用函数时存活,函数调用完毕后则销毁
def func(a,b):
pass
func(10,1)
func(11,12)
func(13,14)
func(15,16)#分别创建不同的局部名称空间
2.4 名称空间的加载顺序
内置名称空间>全局名称空间>局部名称空间
2.5 名称空间的销毁顺序
局部名称空间>全局名空间>内置名称空间
2.6 名称空间的查找优先级
当前所在的位置向上一层一层查找
如果当前在局部名称空间:
局部名称空间—>全局名称空间->内置名称空间
input=333
def func():
# input=444
print(input)
func()
如果当前在全局名称空间
全局名称空间->内置名称空间
input=333
def func():
input=444
func()
print(input)
示范1:
def func():
print(x)
x=111
func()
示范2:名称空间的"嵌套"关系是以函数定义阶段为准,与调用位置无关
x=1
def func():
print(x)
def foo():
x=222
func()
foo()
示范3:函数嵌套定义
input=111
def f1():
def f2():
# input=333
print(input)
input=222
f2()
f1()
示范4:
x=111
def func():
print(x) #
x=222
func()
3. 作用域-》作用范围
3.1 全局作用域:
内置名称空间、全局名称空间
特点:
- 1、全局存活
- 2、全局有效:被所有函数共享
x=111
def foo():
print(x,id(x))
def bar():
print(x,id(x))
foo()
bar()
print(x,id(x))
3.2 局部作用域:
局部名称空间的名字
特点:
- 1、临时存活
- 2、局部有效:函数内有效
def foo(x):
def f1():
def f2():
print(x)
4. global和nonlocal
4.1 LEGB模式
# LEGB
# builtin
# global
def f1():
# enclosing
def f2():
# enclosing
def f3():
# local
pass
4.2 global:在局部修改全局的名字对应的值(不可变类型)
#示范1:
x=111
def func():
global x # 声明x这个名字是全局的名字,不要再造新的名字了
x=222
func()
print(x)
#示范2:对于不可变类型,不需要再次定义
l=[111,222]
def func():
l.append(333)
func()
print(l)
4.3 nonlocal: 修改函数外层函数包含的名字对应的值(不可变类型)
x=0
def f1():
x=11
def f2():
nonlocal x
x=22
f2()
print('f1内的x:',x)
f1()