python函数——形参中的:*args和**kwargs
python函数——形参中的:*args和**kwargs
多个实参,放到一个元组里面,以*开头,可以传多个参数;**是形参中按照关键字传值把多余的传值以字典的方式呈现
*args:(表示的就是将实参中按照位置传值,多出来的值都给args,且以元祖的方式呈现)
示例:
1
2
3
4
5
|
def foo(x, * args): print (x) print (args) foo( 1 , 2 , 3 , 4 , 5 ) #其中的2,3,4,5都给了args |
执行结果是:
1
2
|
1 ( 2 , 3 , 4 , 5 ) |
当args与位置参数和默认参数混用的情况下:(注意三者的顺序)
示例一、(三者顺序是:位置参数、默认参数、*args)
1
2
3
4
5
6
|
def foo(x,y = 1 , * args): print (x) print (y) print (args) foo( 1 , 2 , 3 , 4 , 5 ) #其中的x为1,y=1的值被2重置了,3,4,5都给了args |
执行结果是:
1
2
3
|
1 2 ( 3 , 4 , 5 ) |
示例二、(三者顺序是:位置参数、*args、默认参数)
1
2
3
4
5
6
|
def foo(x, * args,y = 1 ): print (x) print (args) print (y) foo( 1 , 2 , 3 , 4 , 5 ) #其中的x为1,2,3,4,5都给了args,y按照默认参数依旧为1 |
执行结果是:
1
2
3
|
1 ( 2 , 3 , 4 , 5 ) 1 |
其中关于*,可以从2个角度来看(需要拆分来看):
1、从形参的角度来看:
示例:
1
2
3
|
def foo( * args): #其实这一操作相当于def foo(a,b,c,d,e): print (args) foo( 1 , 2 , 3 , 4 , 5 ) #其中的1,2,3,4,5都按照位置传值分别传给了a,b,c,d,e |
执行结果是:
1
|
( 1 , 2 , 3 , 4 , 5 ) |
2、从实参的角度来看:
示例:
1
2
3
4
5
6
|
def foo(x,y,z): print (x) print (y) print (z) foo( * ( 1 , 2 , 3 )) #其中的*(1,2,3)拆开来看就是:foo(1,2,3),都按照位置传值分别传给了x,y,z |
执行结果是:
1
2
3
|
1 2 3 |
——————————————————————————————————————————————————————————————————————————————————————
**kwargs:(表示的就是形参中按照关键字传值把多余的传值以字典的方式呈现)
示例:
1
2
3
4
|
def foo(x, * * kwargs): print (x) print (kwargs) foo( 1 ,y = 1 ,a = 2 ,b = 3 ,c = 4 ) #将y=1,a=2,b=3,c=4以字典的方式给了kwargs |
执行结果是:
1
2
|
1 { 'y' : 1 , 'a' : 2 , 'b' : 3 , 'c' : 4 } |
关于**kwargs与位置参数、*args、默认参数混着用的问题:(注意顺序)
位置参数、*args、**kwargs三者的顺序必须是位置参数、*args、**kwargs,不然就会报错:
示例:
1
2
3
4
5
|
def foo(x, * args, * * kwargs): print (x) print (args) print (kwargs) foo( 1 , 2 , 3 , 4 ,y = 1 ,a = 2 ,b = 3 ,c = 4 ) #将1传给了x,将2,3,4以元组方式传给了args,y=1,a=2,b=3,c=4以字典的方式给了kwargs |
执行结果是:
1
2
3
|
1 ( 2 , 3 , 4 ) { 'y' : 1 , 'a' : 2 , 'b' : 3 , 'c' : 4 } |
错误示例:(由于顺序错误)
1
2
3
4
5
|
def foo(x, * * kwargs, * args): print (x) print (args) print (kwargs) foo( 1 ,y = 1 ,a = 2 ,b = 3 ,c = 4 , 2 , 3 , 4 ) |
执行结果就会报错:
1
|
SyntaxError: invalid syntax |
位置参数、默认参数、**kwargs三者的顺序必须是位置参数、默认参数、**kwargs,不然就会报错:
示例:
1
2
3
4
5
|
def foo(x,y = 1 , * * kwargs): print (x) print (y) print (kwargs) foo( 1 ,a = 2 ,b = 3 ,c = 4 ) #将1按照位置传值给x,y按照默认参数为1,a=2,b=3,c=4以字典的方式给了kwargs |
执行结果是:
1
2
3
|
1 1 { 'a' : 2 , 'b' : 3 , 'c' : 4 } |
其中关于**,可以从2个角度来看(需要拆分来看):
1、从形参的角度来看:
示例:
1
2
3
|
def foo( * * kwargs): #其实就是相当于def foo(y,a,b,c) print (kwargs) foo(y = 1 ,a = 2 ,b = 3 ,c = 4 ) |
执行结果是:
1
|
{ 'y' : 1 , 'a' : 2 , 'b' : 3 , 'c' : 4 } |
2、从实参的角度来看:
示例一:
1
2
3
4
5
6
|
def foo(a,b,c,d): print (a) print (b) print (c) print (d) foo( * * { "a" : 2 , "b" : 3 , "c" : 4 , "d" : 5 }) #**{"a":2,"b":3,"c":4,"d":5}是将字典里的每个值按照关键字传值的方式传给a,b,c,d |
执行结果是:
1
2
3
4
|
2 3 4 5 |
示例二:
1
2
3
4
5
6
|
def foo(a,b,c,d = 1 ): print (a) print (b) print (c) print (d) foo( * * { "a" : 2 , "b" : 3 , "c" : 4 }) #**{"a":2,"b":3,"c":4}是将字典里的每个值按照关键字传值的方式传给a,b,c;d依旧按照默认参数 |
执行结果是:
1
2
3
4
|
2 3 4 1 |
python函数——形参中的:*args和**kwargs的更多相关文章
- python函数形参中的*args和**kwargs
转载:https://www.cnblogs.com/xuyuanyuan123/p/6674645.html 多个实参,放到一个元组里面,以*开头,可以传多个参数:**是形参中按照关键字传值把多余的 ...
- 【python】参数中的*args和**kwargs
转自https://www.cnblogs.com/xuyuanyuan123/p/6674645.html#undefined 多个实参,放到一个元组里面,以*开头,可以传多个参数:**是形参中按照 ...
- Python中的args和kwargs
有时,你会看到python中定义函数的时候带有两个奇怪的参数:*args.**kwargs.如果你曾经想知道它们是干什么的,或者想知道你的IDE为什么在main()函数中定义它们,那么本文可以帮助到你 ...
- python函数—形参、实参、位置参数、关键字参数
1.通过def function_name([parameter]): 定义,函数一遇到return即结束运行.如果函数没有定义返回值,则返回None,如果定义了一个返回值,则返回该对象,如果一个re ...
- Python - 函数形参之必填参数、缺省参数、可变参数、关键字参数的详细使用
Python函数形参 必传参数:平时最常用的,必传确定数量的参数 缺省参数:在调用函数时可以传也可以不传,如果不传将使用默认值 可变参数:可变长度参数 关键字参数:长度可变,但是需要以kv对形式传参 ...
- 跟着太白老师学python 10day 函数的动态参数 *args, **kwargs, 形参的位置顺序
1. *args 接收实参的位置参数, **kwargs接收实参的关键字参数 def func(*args, **kwargs): print(args, kwargs) func(1, 2, 3, ...
- python:函数中的*args与**kwargs
首先定义一个包含*args和**kwargs的函数,这个函数唯一的功能就是输出自己的两个参数,以此来理解*args和**kwargs def myFunc(*args, **kwargs): prin ...
- python中的*args与**kwargs的含义与作用
在定义函数的时候参数通常会使用 *args与**kwgs,形参与实参的区别不再赘述,我们来解释一下这两个的作用. *args是非关键字参数,用于元组,**kwargs是关键字参数 (字典)例如下面的代 ...
- 理解 Python 中的 *args 和 **kwargs
Python是支持可变参数的,最简单的方法莫过于使用默认参数,例如: def test_defargs(one, two = 2): print 'Required argument: ', one ...
随机推荐
- [luogu2590][bzoj1036][ZJOI2008]树的统计
题目描述 一棵树上有n个节点,编号分别为1到n,每个节点都有一个权值w.我们将以下面的形式来要求你对这棵树完成 一些操作: I. CHANGE u t : 把结点u的权值改为t II. QMAX u ...
- 【转】STC51单片机下载程序的时候不要在VCC端接DHT11
今天使用51单片机学习板调试DHT11湿度传感器,下载程序的时候把DHT11烧掉了. 一开始我使用杜邦线把DHT11的VCC引脚接到学习板上的VCC端,GND接GND,数据端口接51单片机的P0.0. ...
- Elasticsearch利用cat api快速查看集群状态、内存、磁盘使用情况
使用场景 当Elasticsearch集群中有节点挂掉,我们可以去查看集群的日志信息查找错误,不过在查找错误日志之前,我们可以通过elasticsearch的cat api简单判断下各个节点的状态,包 ...
- 洛谷P3474 KUP-Plot purchase
简要题意: 给你一个n * n的非负矩阵,求问是否有子矩阵满足和在[k, 2k]之间.若有输出方案.n<=2000. 解: 首先n4暴力很好想(废话),然后发现可以优化成n3log2n,但是还是 ...
- A1060. Are They Equal
If a machine can save only 3 significant digits, the float numbers 12300 and 12358.9 are considered ...
- 2018.9青岛网络预选赛(B)
传送门:Problem(B) https://www.cnblogs.com/violet-acmer/p/9664805.html 参考资料: https://blog.csdn.net/qq_40 ...
- js变量浅谈
js变量是除了this以外最让人恶心的东西了,还因为烂语法造成各种各样奇奇怪怪的事情发生,下面让我们来谈谈都有什么奇怪的事: 1.用var与不用var function test(){ a = 123 ...
- circRNA
一.circRNA序列提取 环状RNA (circRNA)是一类不具有 5' 末端帽子和 3' 末端 poly(A)尾巴.并以共价键形成环形结构的非编码 RNA 分子. 环状RNA (circRNA) ...
- Unity触发器有时失效的原因
unity里面的触发器有时候不起作用,我原以为是失效了.其实是这样的,所谓触发器就是被触发的物体,例如你子弹打小怪.如果把子弹设置成触发器那么是不成功的,因为子弹是主动的啊,那么把小怪设置成触发器了呢 ...
- JVM总结(四):JVM类加载机制
这一节我们来总结一下JVM类加载机制.具体目录如下: 类加载的过程 类加载过程概括 说说引用 详解类加载全过程: 加载 验证 准备 解析 初始化 虚拟机把描述类的数据从Class文件加载到内存,并对数 ...