形参:在定义函数阶段定义的参数称之为形式参数,简称形参,用于接收实参的传入,相当于变量名.
def func(x, y): # x=1,y=2
print(x, y)
在调用函数阶段往函数括号内传入的值称之为实际参数,简称实参,相当于变量值
func(2,3)
1、在调用函数的时候,实参(变量值)会绑定给形参(变量名)
2、这种绑定关系只能在函数体内使用,函数调用时绑定关系生效,只要函数调用结束两者就会立即解除绑定。
func(1,2) #直接传入具体的值
x = 1
y = 2
func(x, y) #传入变量名,即传入一个值的绑定关系
def bar(x, y):
res=x + y
return res
func(int('1'), 2)
func(str(1), '2')
func(bar(1,2), 2) #传入的是python内置函数的调用或其他自定义函数的调用
———》总结:无论传入的实参是值、变量、python内置函数还是自定义的函数调用,只要最终得到的结果是一个值就行
按照从左到右的顺序依次定义或者调用时依次传入的参数称之为位置参数(位置形参,位置实参)
特点:必须被传值,多一个不行少一个也不行,即实参和形参必须一一对应
def func(x, y):
print(x, y)
func(1, 2, ) # 1 2
func() # 没有传入任何实参报错
func(1) # 没有向y形参传入实参报错
func(1, 2, 3) # 传入的实参过多报错
def func(x, y):
print(x - y)
func(1, 2) #-1
func(2, 1) #1 实参位置顺序不同结果不同
在函数调用阶段,按照key=value的形式传入的值,指名道姓给某个形参传值,可以完全不参照顺序
def func(x, y, z):
print(x, y, z)
func(x=1, z=2, y=3)
func(z=1, x=2, y=3)
func(z=1, y=2, x=3) #三种实参传入顺序不同,但结果相同
强调1:位置实参和关键字实参混用时,关键字实参一定要在位置实参之后
def func(x, y, z):
print(x, y, z)
func(1, 2, z=3)
func(1, y=2, z=3)
func(x=1, 2, z=3) # 报错positional argument follows keyword argument
func(x=1, y=2, 3) # 报错positional argument follows keyword argument
强调2:**不能能为同一个形参重复传值
def func(x, y):
print(x, y)
func(1, 2, y=3) # y重复传值报错 got multiple values for argument 'y'
func(1, 2, x=3, y=4) # x,y重复传值
在定义函数阶段,就已经被赋值的形参,称之为默认参数
特点:在定义阶段就已经被赋值,意味着在调用阶段可以不用为其赋值,但也可以重新赋值。
def func(x, y=3):
print(x, y)
func(4) #用y可以不用赋值
func(4, 5) #y也能用进行用位置实参赋值
func(4, y=5) #y还可以用关键字实参进行新的赋值
强调1:位置形参与默认形参混用时,位置形参必须在默认形参的左边
强调2:默认的参数的值是在函数定义阶段被赋值的,准确地说是在函数定义时形参已经绑定了一个值的内存地址,所以绑定的值是不可变时函数调用时不会受到影响,如果值是可变的时候,函数的调用有可能有受到其他代码的影响
强调3:虽然默认值可以被指定为任意数据类型,但是不推荐使用可变类型函数最理想的状态:函数的调用只跟函数本身有关系,不外界代码的影响。
可变长度指的是在调用函数时,传入的值(实参)的个数不固定而实参是用来为形参赋值的,所以对应着,针对溢出的实参必须有对应的形参来接收
形参名:用来接收溢出的位置实参,溢出的位置实参会被保存成元组的格式然后赋值紧跟其后的形参名
后跟的可以是任意名字,但是约定俗成应该是args
def func(x,y,*z): #z=(3,4,5,6)
print(x,y,z)
func(1,2,3,4,5,6)
def func(x,y,*args):
print(x,y,args)
func(1,2,3,[4,5,6])
func(1,2,*[3,4,5,6])
func(*'beautiful')
**形参名:用来接收溢出的关键字实参,会将溢出的关键字实参保存成字典格式,然后赋值给紧跟其后的形参名
**后跟的可以是任意名字,但是约定俗成应该是kwargs
def func(x,y,**kwargs):
print(x,y,kwargs)
func(x=1,y=2,a=3,b=4,e=5)
**实参:可以用在实参中(后跟的只能是字典),实参中带,先后的值打散成关键字实参
def func(x,y,z):
print(x,y,z)
func(*{'x':1,'y':2,'z':3}) #func('x','y','z')
func(**{'x':1,'y':2,'z':3}) #func(x=1,y=2,z=3)
def func(x,y,**kwargs):
print(x,y,kwargs)
func(**{'y':1,'x':2,'a':3,'b':4})
注意:混用*与**:*args必须在**kwargs之前
def index(x,y,z):
print('index=>>>',x,y,z)
def wrapper(*args,**kwargs):
index(*args,**kwargs)
wrapper(1,2,{1,2,3})
wrapper(1,2,3)
wrapper(x=1,y=2,z=3)
wrapper({'a':1},{'b':2},{'c':3})
wrapper([1,],{'a':2},(3,4,5))
wrapper('a',1,[2,3])
wrapper(None,True,None)
wrapper([None,'1'],(True,1),{'2':'none'})
wrapper(({'a':1}),([1,2]),1)
wrapper({'a':[1,(3,4)]},{"b":None},{'c':[1,{'a':1}]})
wrapper(1,z=3,y=2) # 为wrapper传递的参数是给index用的
原格式---》汇总-----》打回原形
原文:https://www.cnblogs.com/zhangtieshan/p/12521603.html