可以将可变数量的参数传递给函数吗?

类似于在C或c++中使用varargs:

fn(a, b)
fn(a, b, c, d, ...)
428693 次浏览

是的。你可以使用*args作为non-keyword参数。然后,您将能够传递任意数量的参数。

def manyArgs(*arg):
print "I was called with", len(arg), "arguments:", arg


>>> manyArgs(1)
I was called with 1 arguments: (1,)
>>> manyArgs(1, 2, 3)
I was called with 3 arguments: (1, 2, 3)

正如你所看到的,Python将解压缩参数作为包含所有参数的单个元组。

对于关键字参数,你需要接受它们作为一个单独的实际参数,如Skurmedel的回答所示。

添加到unwind post:

你也可以发送多个键值参数。

def myfunc(**kwargs):
# kwargs is a dictionary.
for k,v in kwargs.iteritems():
print "%s = %s" % (k, v)


myfunc(abc=123, efh=456)
# abc = 123
# efh = 456

你可以将两者混合:

def myfunc2(*args, **kwargs):
for a in args:
print a
for k,v in kwargs.iteritems():
print "%s = %s" % (k, v)


myfunc2(1, 2, 3, banan=123)
# 1
# 2
# 3
# banan = 123

它们必须按此顺序声明和调用,也就是说函数签名需要是*args, **kwargs,并按此顺序调用。

加上其他优秀的帖子。

有时你不想指定而且想要为它们使用键的参数的数量(如果在字典中传递的一个参数没有在方法中使用,编译器将报错)。

def manyArgs1(args):
print args.a, args.b #note args.c is not used here


def manyArgs2(args):
print args.c #note args.b and .c are not used here


class Args: pass


args = Args()
args.a = 1
args.b = 2
args.c = 3


manyArgs1(args) #outputs 1 2
manyArgs2(args) #outputs 3

然后你就可以做

myfuns = [manyArgs1, manyArgs2]
for fun in myfuns:
fun(args)
def f(dic):
if 'a' in dic:
print dic['a'],
pass
else: print 'None',


if 'b' in dic:
print dic['b'],
pass
else: print 'None',


if 'c' in dic:
print dic['c'],
pass
else: print 'None',
print
pass
f({})
f({'a':20,
'c':30})
f({'a':20,
'c':30,
'b':'red'})
____________

上面的代码将输出

None None None
20 None 30
20 red 30

这与通过字典传递变量参数一样好

如果我可以,Skurmedel的代码是python 2;为了适应python 3,将iteritems改为items,并在print中添加圆括号。这可以防止像我这样的初学者遇到: AttributeError: 'dict' object has no attribute 'iteritems'和搜索其他地方(例如当尝试使用NetworkX的write_shp()时,错误" 'dict'对象没有'iteritems'属性")为什么会发生这种情况
def myfunc(**kwargs):
for k,v in kwargs.items():
print("%s = %s" % (k, v))


myfunc(abc=123, efh=456)
# abc = 123
# efh = 456

和:

def myfunc2(*args, **kwargs):
for a in args:
print(a)
for k,v in kwargs.items():
print("%s = %s" % (k, v))


myfunc2(1, 2, 3, banan=123)
# 1
# 2
# 3
# banan = 123

另一种方法,除了前面提到的很好的答案,取决于这样一个事实,即您可以通过位置传递可选的命名参数。例如,

def f(x,y=None):
print(x)
if y is not None:
print(y)

收益率

In [11]: f(1,2)
1
2


In [12]: f(1)
1