地点参数必需在主要字参数的眼下

一、地方参数

调用函数时根据函数定义的参数地点来传递参数。

#!/usr/bin/env python
# coding=utf-8

def print_hello(name, sex):
    sex_dict = {1: u'先生', 2: u'女士'}
    print 'hello %s %s, welcome to python world!' %(name, sex_dict.get(sex, u'先生'))


# 两个参数的顺序必须一一对应,且少一个参数都不可以
# print_hello('tanggu', 1)

二、关键字参数

用来函数调用,通过“键-值”方式加以钦定。能够让函数特别鲜明、轻巧选拔,相同的时间也排除了参数的逐条须要。

# 以下是用关键字参数正确调用函数的实例
# print_hello('tanggu', sex=1)
# print_hello(1, name='tanggu')
# print_hello(name='tanggu', sex=1)
# print_hello(sex=1, name='tanggu')

# 以下是错误的调用方式
# print_hello(name='tanggu', 1)
# print_hello(sex=1, 'tanggu')

经过地点的代码,大家能够发掘:有职分参数时,地点参数必需在显要字参数的先头,但首要字参数之间官样文章前后相继顺序的

三、暗许参数

用来定义函数,为参数提供暗许值,调用函数时可传可不传该默许参数的值(注意:全数职位参数必得出现在暗中认可参数前,包括函数定义和调用)

# 正确的默认参数定义方式--> 位置参数在前,默认参数在后
def print_hello(name, sex=1):
    ....

# 错误的定义方式
def print_hello(sex=1, name):
    ....

# 调用时不传sex的值,则使用默认值1
# print_hello('tanggu')

# 调用时传入sex的值,并指定为2
# print_hello('tanggu', 2)

四、可变参数

概念函数时,不经常候大家不鲜明调用的时候会传送多少个参数(不传参也足以)。此时,可用包裹(packing)地点参数,也许包裹关键字参数,来进展参数字传送递,会显得特别方便。

1、包裹地方传递

def func(*args):
    ....


# func()
# func(a)
# func(a, b, c)

我们传进的富有参数都会被args变量搜集,它会依照传进参数的职分合併为一个元组(tuple),args是元组类型,这正是包装地点传递。

2、包裹关键字传递

def func(**kargs):
    ....

# func(a=1)
# func(a=1, b=2, c=3)

kargs是叁个字典(dict),收罗全体入眼字参数

五、解包裹参数

*和**,也足以在函数调用的时候利用,称之为解包裹(unpacking)

澳门新蒲京官网,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'男'}

六、地点参数、暗中同意参数、可变参数的因陋就简使用

大旨条件是:先地方参数,私下认可参数,包裹地方,包裹关键字(定义和调用都应遵守)

def func(name, age, sex=1, *args, **kargs):
    print name, age, sex, args, kargs


# func('tanggu', 25, 2, 'music', 'sport', class=2)
# tanggu 25 1 ('music', 'sport') {'class'=2}

 Python中 *args 和 **kwargs
的区别

先来看个例证:

def foo(*args, **kwargs):
    print 'args = ', args
    print 'kwargs = ', kwargs
    print '---------------------------------------'

if __name__ == '__main__':
    foo(1,2,3,4)
    foo(a=1,b=2,c=3)
    foo(1,2,3,4, a=1,b=2,c=3)
    foo('a', 1, None, a=1, b='2', c=3)

出口结果如下:

args =  (1, 2, 3, 4) 
kwargs =  {} 
--------------------------------------- 
args =  () 
kwargs =  {'a': 1, 'c': 3, 'b': 2} 
--------------------------------------- 
args =  (1, 2, 3, 4) 
kwargs =  {'a': 1, 'c': 3, 'b': 2} 
--------------------------------------- 
args =  ('a', 1, None) 
kwargs =  {'a': 1, 'c': 3, 'b': '2'}

能够看出,这七个是Python中的可变参数。*args 表示其他多个名不见经传参数,它是叁个tuple;**kwargs 表示关键字参数,它是三个dict。並且同一时候使用*args**kwargs时,必须*args参数列要在**kwargs前,像foo(a=1, b='2', c=3, a', 1, None, )诸如此比调用的话,会提醒语法错误“SyntaxError: non-keyword arg after keyword arg”

知道*args和`**kwarg是怎么样了啊。还会有叁个很美丽观的用法,就是创制字典:

    def kw_dict(**kwargs):
        return kwargs
    print kw_dict(a=1,b=2,c=3) == {'a':1, 'b':2, 'c':3}

实质上python中就隐含dict类,使用dict(a=1,b=2,c=3)就能够创制叁个字典了。

 

*args:

  重点在*,前边的args也正是五个变量名,能够团结定义的。它的真面目就是将正式调用剩下的值集中间转播变为元组。

#*args的运用
def foo (x,*args):
    print(x)
    print(args)

foo(1,2,3,4,5,6,6,'a','b')  #调用函数

输出:

 1—–>x
(2, 3, 4, 5, 6, 6, ‘a’, ‘b’)—–>*args

#从形参的角度
def foo(*args):  # foo(x,y,z)参数个数可以至多个
    print(args)

foo(1, 2, 3)  # 没有个数限制
(1, 2, 3)      #输出结果
#*args=*(1,2,3)

从实参的角度
def bar(x,y,z):
    print(x)
    print(y)
    print(z)

# bar(*(1,2,3,4)) #会报错只需要3个值,但给定的实参有4个值,不能一一对应
bar(*(1,2,3))   #实参一一对应
1
2
3

*args与岗位参数和暗中同意参数混用:(输出元组)

#*args与位置参数和默认参数混用:*args要放到位置参数后面,默认参数要放最后。
def foo(x,*args,y = 1):
    print(x)
    print(y)
    print(args)
foo(1,2,3,4,5,6,7,8,9,10,y=10000)   #调用函数
1------->x=1
10000-------->y=10000
(2, 3, 4, 5, 6, 7, 8, 9, 10)----->args的值变成元组

**kwargs(输出字典)

重点在**,后面的kwargs相当于一个变量名,可以自己定义的。它的本质就是将关键字调用剩下的值集中转变为字典。
def foo(x,**kwargs):    #kwargs = {'y':1,'z': 2}
    print(x)
    print(kwargs)
foo(1,y=1,z=2)      #调用函数
# 1-->x的值
# {'y': 1, 'z': 2} #kwargs的值,转为了一个字典

从区别角度看**kwargs:

def foo(**kwargs):  #foo(x=1,y=2,z=3)参数个数可以一个至多个
    print(kwargs)

foo(x=1,y=2,z=3)  #调用函数,没有个数限制
{'x': 1, 'y': 2, 'z': 3}  ----->输出字典
--------------分割线-------------------------
def foo(x,y,z):
    print(x)
    print(y)
    print(z)
# foo(**{'x' : 1,'y' : 2, 'z' : 3,"a":4 })#TypeError: foo() got an unexpected keyword argument 'a',报错原因是函数foo只有3个值(x,y,z)
foo(**{'x' : 1,'y' : 2, 'z' : 3})   #三个值正好匹配
1#输出结果
2
3

**kwargs与地方参数和暗许参数混用:

def foo(x,a = 4,**kwargs):  #混合使用参数
    print(x)
    print(a)
    print(kwargs)

foo(1,y=2,z=3)  #使用默认参数

1  #输出
4
{‘y’: 2, ‘z’: 3}

 

foo(1,5,y=2,z=3)  #修改暗中同意参数

1
5
{‘y’: 2, ‘z’: 3}

超复杂混合参数混用记:

从形参角度:

def foo(x,*args,a=4,**kwargs):  #使用默认参数时,注意默认参数的位置要在args之后kwargs之前
    print(x)
    print(a)
    print(args)
    print(kwargs)

foo(1,5,6,7,8,y=2,z=3)  #调用函数,不修改默认参数
1   #x的值
4   #a的值
(5, 6, 7, 8)   #*args的值
{'y': 2, 'z': 3}    ##kwargs的值

def foo(x,a=4,*args,**kwargs):  ##注意:当需要修改默认参数时,要调整默认参数的位置,要放在args之前即可,但不可放在开头。
    print(x)
    print(a)
    print(args)
    print(kwargs)

foo(1,9,5,6,7,8,y=2,z=3)    #调用函数,修改默认参数a为9
1   #x的值
9   #被修改后a的值
(5, 6, 7, 8)    #args的值
{'y': 2, 'z': 3}    #kwargs的值

从实参角度:

def foo(x,*args,a=4,**kwargs):  #使用默认参数时,注意默认参数的位置要在args之后kwargs之前
    print(x)
    print(a)
    print(args)
    print(kwargs)

foo(1,*(5,6,7,8),**{"y":2,"z":3})   #调用函数,不改默认参数
1   #x的值
4   #默认a的值
(5, 6, 7, 8)    #args的值
{'y': 2, 'z': 3}    #kwargs的值
-------------分割线----------------------

def foo(x,a=4,*args,**kwargs):  #注意:当需要修改默认参数时,要调整默认参数的位置,要放在args之前,但不可放在开头
    print(x)
    print(a)
    print(args)
    print(kwargs)

foo(1,9,10,*(5,6,7,8),**{"y":2,"z":3})  #调用函数,修改默认参数a为9
1   #x的值
9   #修改默认参数a后的值
(10, 5, 6, 7, 8)    #args的值
{'y': 2, 'z': 3}    #kwargs的值

 小结:

职位参数:

调用函数时所传参数的职位必需与概念函数时参数的岗位一样

根本字参数:

行使主要字参数会钦命参数值赋给哪个形参,调用时所传参数的职分能够随便

*地点参数:可承受任性数量的岗位参数(元组);只可以当作最后一个职位参数出现,其后参数均为重大字参数

**主要字参数:可承受任性数量的尤为重要字参数(字典);只可以充作最后多少个参数出现

 

暗许参数:私下认可参数的赋值只会在函数定义的时候绑定壹回,暗许值不会再被修改

  

相关文章

发表评论

电子邮件地址不会被公开。 必填项已用*标注

*
*
Website