类似于在 C 或 C++ 中使用 varargs:
fn(a, b)
fn(a, b, c, d, ...)
类似于在 C 或 C++ 中使用 varargs:
fn(a, b)
fn(a, b, c, d, ...)
可以。你可以将*args
用作非关键字参数,这样就能传递任意数量的参数。
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的答案中所示。
manyArgs(x = 3)
会导致TypeError
。Skumedel的答案提供了解决方案。关键在于函数的一般签名是f(*list_args, **keyword_args)
(而不是f(*list_args)
)。 - Eric O. Lebigotargs
的类型是“元组”。kwargs
代表关键字参数。kwargs
的类型是“字典”。 - RoboAlexfor arg in args:
来迭代传递的参数。 - MasterControlProgram在 unwinds 的回答中补充一点:
你也可以发送多个键值对参数。
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,而且需要按照这个顺序进行调用。
print(a)
替换 print a
,用 kwargs.items()
替换 kwargs.iteritems()
。 - MasterControlProgramlogger.info()
接受的参数怎么办?例如,myLogger('错误:%s', err)
。 - undefined如果我可以的话,Skurmedel的代码是针对Python 2编写的;要将其适应于Python 3,请将iteritems
更改为items
并在print
中添加括号。这可以防止像我这样的初学者遇到以下问题:AttributeError:'dict' object has no attribute 'iteritems'
并且在其他地方搜索(例如Error “ 'dict' object has no attribute 'iteritems' ” when trying to use NetworkX's write_shp())为什么会发生这种情况。
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 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
f = lambda **dic: ' '.join(dic.get(key, 'None') for key in 'abc')
。请注意,这是对原文的翻译,没有额外的解释或信息返回。 - metaperturedef 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