标签:rgs 长度 hello utf-8 int name 参数传递 定义 %s
位置参数:按顺序定义的参数,包涵两个维度实参和形参,需要从两个角度去看
1.在定义函数时,按照从左到右的顺序依次定义形参,称为位置形参
2.在调用函数时,按照从左到右的顺序依次定义实参,称为位置实参
#coding = utf-8 def print_hello(name,age,sex): #name,age,sex位置形参 print(‘Name:%s Age:%s Sex:%s‘ %(name,age,sex)) #‘Muse‘,26,‘男‘ 位置实参 print_hello(‘Muse‘,26,‘男‘)
注:位置实参和位置形参必须一一对应,切一个参数都不可以少
用于函数调用,通过“键-值”形式加以指定。可以让函数更加清晰、容易使用,同时也清除了参数的顺序需求。
#coding = utf-8 def print_hello(name,age,sex): print(‘Name:%s Age:%s Sex:%s‘ %(name,age,sex)) #关键字参数sex=‘male‘,name=‘lili‘,age=18 print_hello(sex=‘male‘,name=‘lili‘,age=18)
用于定义函数,为参数提供默认值,调用函数时可传可不传该默认参数的值,如果不传就取定义时候的值,传了改变为新的值
#coding = utf-8 def print_hello(name,age,sex = ‘女‘ ): #sex = ‘女‘ 为默认参数 print(‘Name:%s Age:%s Sex:%s‘ %(name,age,sex)) print_hello(‘Muse‘,26,‘男‘)
注:1.关键字参数和默认参数的区别:关键字参数是在调用的时候以key = value的形式进行传值的,默认参数是在定义的时候
2.默认参数的值通常应设为不可变类型
3.定义函数的时候,默认参数必须在位置参数之后
1.可变长度的位置参数
在最后一个形参名前加*,溢出的位置参数都会被接收,以元组的形式保存下来赋值给该形参
def foo(x,y,z=1,*args): #在最后一个形参名args前加*号 print(x) print(y) print(z) print(args) foo(1,2,3,4,5,6,7)
2.可变长度的关键字参数
在最后一个形参名前面加**,调用函数时,溢出的关键字参数都会被接收,以字典的形式保存下来赋值给该形参
def foo(x,**kwargs): #在最后一个参数kwargs前加** print(x) print(kwargs) foo(x=1,y=2,z=3) #溢出的关键字实参y=2,z=3都被**接收,以字典的形式保存下来,赋值给kwargs {‘z‘: 3, ‘y‘: 2}
3.解包裹(*和**)
1)在传递元组时,让元祖的每一个元素对应一个位置参数
def print_hello(name, sex): print name, sex # args = (‘tanggu‘, ‘男‘) #两个形参一个实参,运行的时候会解包为一一对应 # print_hello(*args) #运行结果 # tanggu 男
2)在传递字典时,让字典的每个键值对作为一个关键字参数传递给函数
def print_hello(kargs): print kargs kargs = {‘name‘: ‘tanggu‘, ‘sex‘, u‘男‘} print_hello(**kargs) #运行结果 {‘name‘: ‘tanggu‘, ‘sex‘, u‘男‘}
标签:rgs 长度 hello utf-8 int name 参数传递 定义 %s
原文地址:https://www.cnblogs.com/museniuniu/p/12973053.html