一丶形参与实参的介绍函数的参数分为形式参数和实际参数,简称形参和实参 形参:在定义函数阶段定义的参数称之为形式参数,简称形参,相当于变量名 def func(x,y): print(x,y) 实参:在调用函数阶段传入的值称之为实际参数,简称实参,相当于变量值,实参是传入的值,但值可以是以下形式 #1:常量 func(1,2) #2:变量 a=1 b=2 func(a,b) #3:表达式 func(10*2,10*func(3,4)) #4:实参可以是常量、变量、表达式的任意组合 a=2 func(1,a,10*func(3,4)) 形参和实参的关系: 1.在函数调用时实参(值)会绑定给形参(变量名) 2.这种绑定关系只能在函数体内使用 3.绑定关系在函数调用时生效,调用结束后解除绑定关系 二丶形参与实参的具体使用2.1 位置参数:按照从左到右的顺序依次定义的参数称之为位置参数 位置形参:在函数定义阶段,按照从左到右的顺序直接定义的"变量名", 特点:必须被传值,多一个不行少一个也不行 def func(x,y): print(x,y) func(1,2,3) #报错 func(1,) #报错 位置实参:在函数调用阶段, 按照从左到有的顺序依次传入的值, 特点:按照顺序与形参一一对应 func(1,2) >>>1,2 func(2,1) >>>2,1 2.2 关键字参数:关键字实参:在函数调用阶段,按照key=value的形式传入的值 特点:指名道姓给某个形参传值,可以完全不参照顺序 def func(x,y): print(x,y) func(y=2,x=1) >>>1,2 func(1,2) >>>1,2 强调:位置参数和关键字参数的混合使用 # 1、位置实参必须放在关键字实参前 func(1,y=2) #正确 func(y=2,1) #报错 # 2、不能能为同一个形参重复传值 func(1,y=2,x=3) #报错 func(1,2,x=3,y=4) #报错 2.3 默认参数默认形参:在定义函数阶段,就已经被赋值的形参,称之为默认参数 特点:在定义阶段就已经被赋值,意味着在调用阶段可以不用为其赋值 def func(x,y=3): print(x,y) func(x=1) >>>1,3 func(x=1,y=44444) >>>1,44444 强调:位置形参与默认形参混用 1、位置形参必须在默认形参的左边 2、默认参数的值是在函数定义阶段被赋值的,准确地说被赋予的是值的内存地址 # 示范1 m = 2 def func(x,y=m): #y是指向2的内存地址 print(x,y) m=2222222 func(1) # 示范2 m = [111,] def func(x,y=m): #y指向的是[111,]是内存地址 print(x, y) m.append(22222) func(1) 3、虽然默认值可以被指定为任意数据类型,但是不推荐使用可变类型 函数最理想的状态:函数的调用只跟函数本身有关系,不外界代码的影响 def func(x,y,z,l=None): if l is None: l=[] l.append(x) l.append(y) l.append(z) print(l) func(1,2,3) func(4,5,6) new_l=[111,222] func(1,2,3,new_l) 三丶可变长度的参数(*与**的用法)可变长度指的是在调用函数时,传入的值(实参)的个数不固定 而实参是用来为形参赋值的,所以对应着,针对溢出的实参必须有对应的形参来接收 3.1 可变长度的位置参数1.形参中带*:*形参名:用来接收溢出的位置实参,溢出的位置实参会被*保存成元组的格式然后赋值紧跟其后的形参名,*后跟的可以是任意名字,但是约定俗成应该是args def my_sum(*args): res = 0 for item in args: res = item return res res = my_sum(1,2,3,4) print(res) 2.实参中带*:先将*后的值打散成位置实参 def func(x,y,z): print(x,y,z) func(*[11,22,33]) # func(11,22,33) l=[11,22,33] func(*l) #func(11,22,33) 3.形参与实参中都带*:先将带*的实参打散,然后在赋值给形参 def func(x,y,*args): print(x,y,args) func(1,2,[3,4,5,6]) func(1,2,*[3,4,5,6]) # func(1,2,3,4,5,6) func(*'hello') # func('h','e','l','l','o') 3.2 可变长度的关键字参数1.形参中带**:**形参名:用来接收溢出的关键字实参,**会将溢出的关键字实参保存成字典格式,然后赋值给紧跟其后的形参名,**后跟的可以是任意名字,但是约定俗成应该是kwargs def func(x,y,**kwargs): print(x,y,kwargs) func(1,y=2,a=1,b=2,c=3) 2.实参中带**(**后跟的只能是字典):先**后的值打散成关键字实参 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) #错误 func(**{'x':1,'y':2,}) # func(x=1,y=2) 少参数 func(**{'x':1,'a':2,'z':3}) # func(x=1,a=2,z=3) 没有a对应的形参名 3.形参与实参中都带**:先将带**的实参打散,然后在赋值给形参 def func(x,y,**kwargs): print(x,y,kwargs) func('y':222,**{'x':111,'a':333,'b':4444}) 混用*与**:*args必须在**kwargs之前 def index(x,y,z): print('index=>>> ',x,y,z) def wrapper(*args,**kwargs): index(*args,**kwargs) print(args) print(kwargs) wrapper(1,2,3) wrapper(1,2,[3,4]) wrapper(1,2,z=3) wrapper(1,[2,3],z=2) # 为wrapper传递的参数是给index用的 # 原格式---》汇总-----》打回原形来源:https://www./content-4-662751.html |
|