写点什么

Python 进阶 (二十四)Python 中函数的参数定义和可变参数

  • 2022-10-16
    上海
  • 本文字数:1243 字

    阅读完需:约 1 分钟

Python进阶(二十四)Python中函数的参数定义和可变参数

刚学用 Python 的时候,特别是看一些库的源码时,经常会看到func(*args, **kwargs)这样的函数定义,这个***让人有点费解。其实只要把函数参数定义搞清楚了,就不难理解了。


先说说函数定义,我们都知道,下面的代码定义了一个函数 funcA


def funcA():  pass
复制代码


显然,函数 funcA 没有参数。下面这个函数 funcB 就有两个参数了,


def funcB(a, b):  print a  print b
复制代码


调用的时候,我们需要使用函数名,加上圆括号扩起来的参数列表,比如 funcB(100, 99),执行结果是:10099


很明显,参数的顺序和个数要和函数定义中一致,如果执行 funcB(100),Python 会报错的:


TypeError: funcB() takes exactly 2 arguments (1 given)
复制代码


我们可以在函数定义中使用参数默认值,比如


def funcC(a, b=0):  print a  print b
复制代码


在函数 funcC 的定义中,参数 b 有默认值,是一个可选参数,如果我们调用 funcC(100),b 会自动赋值为 0。


OK,目前为止,我们要定义一个函数的时候,必须要预先定义这个函数需要多少个参数(或者说可以接受多少个参数)。一般情况下这是没问题的,但是也有在定义函数的时候,不能知道参数个数的情况(想一想 C 语言里的printf函数),在Python里,带*的参数就是用来接受可变数量参数的。看一个例子


def funcD(a, b, *c):  print a  print b  print "length of c is: %d " % len(c)  print c
复制代码


调用 funcD(1, 2, 3, 4, 5, 6)结果是 12length of c is: 4(3, 4, 5, 6)


我们看到,前面两个参数被 a、b 接受了,剩下的 4 个参数,全部被 c 接受了,c 在这里是一个tuple。我们在调用 funcD 的时候,至少要传递 2 个参数,2 个以上的参数,都放到 c 里了,如果只有两个参数,那么 c 就是一个empty tuple


好了,一颗星我们弄清楚了,下面轮到两颗星。


上面的例子里,调用函数的时候,传递的参数都是根据位置来跟函数定义里的参数表匹配的,比如 funcB(100, 99)和 funcB(99, 100)的执行结果是不一样的。在Python里,还支持一种用关键字参数(keyword argument)调用函数的办法,也就是在调用函数的时候,明确指定参数值赋值给哪个形参。比如还是上面的 funcB(a, b),我们通过这两种方式调用


funcB(a=100, b=99)
复制代码



funcB(b=99, a=100)
复制代码


结果跟 funcB(100, 99)都是一样的,因为我们在使用关键字参数调用的时候,指定了把 100 赋值给 a,99 赋值给 b。也就是说,关键字参数可以让我们在调用函数的时候打乱参数传递的顺序!


另外,在函数调用中,可以混合使用基于位置匹配的参数和关键字参数,前题是先给出固定位置的参数,比如


def funcE(a, b, c):  print a  print b  print c
复制代码


调用 funcE(100, 99, 98)和调用 funcE(100, c=98, b=99)的结果是一样的。好了,经过以上铺垫,两颗星总算可以出场了:


如果一个函数定义中的最后一个形参有 ** (双星号)前缀,所有正常形参之外的其他的关键字参数都将被放置在一个字典中传递给函数,比如:


def funcF(a, **b):  print a  for x in b:    print x + ": " + str(b[x])
复制代码


调用 funcF(100, c='你好', b=200),执行结果 100c: 你好 b: 200 大家可以看到,b 是一个dict对象实例,它接受了关键字参数 b 和 c。

发布于: 刚刚阅读数: 6
用户头像

No Silver Bullet 2021-07-09 加入

岂曰无衣 与子同袍

评论

发布
暂无评论
Python进阶(二十四)Python中函数的参数定义和可变参数_Python_No Silver Bullet_InfoQ写作社区