“关键字参数”与普通参数有何不同?难道不是所有的参数都可以使用 name=value
来代替位置语法吗?
“关键字参数”与普通参数有何不同?难道不是所有的参数都可以使用 name=value
来代替位置语法吗?
有两个相关的概念,都称为“关键字参数”。
在调用函数的一侧,正如其他评论者所提到的那样,您可以通过名称指定一些函数参数。您必须在没有名称(位置参数)的所有参数之后提及它们,并且对于任何未完全提及的参数必须有默认值。
另一个概念是在函数定义方面:您可以定义一个按名称接收参数的函数--甚至不必指定这些名称是什么。这些是纯关键字参数,不能以位置方式传递。 语法是
def my_function(arg1, arg2, **kwargs)
你传递到这个函数里的任何关键字参数将被放置在一个名为kwargs
的字典中。你可以在运行时检查这个字典的键,例如:
def my_function(**kwargs):
print str(kwargs)
my_function(a=12, b="abc")
{'a': 12, 'b': 'abc'}
kwargs
еҗ—пјҹжҲ–иҖ…жҲ‘еҸҜд»Ҙе°Ҷе…¶йҮҚе‘ҪеҗҚдёәзұ»дјјoptions
зҡ„еҗҚз§°пјҲdef my_function(arg1, arg2, **options)
пјүпјҹ - Bruce Sunmy_function(x='kw-x', y='kw-y', arg2='pos-a2', arg1='pos-a1')
。 - Ed Randall还有一项语言特性,区别非常重要。考虑以下函数:
def foo(*positional, **keywords):
print "Positional:", positional
print "Keywords:", keywords
*positional
参数将存储传递给foo()
的所有位置参数,不限定数量。
>>> foo('one', 'two', 'three')
Positional: ('one', 'two', 'three')
Keywords: {}
keywords
参数将存储任何关键字参数:
>>> foo(a='one', b='two', c='three')
Positional: ()
Keywords: {'a': 'one', 'c': 'three', 'b': 'two'}
当然,你可以同时使用两者:
>>> foo('one','two',c='three',d='four')
Positional: ('one', 'two')
Keywords: {'c': 'three', 'd': 'four'}
这些功能很少被使用,但偶尔它们非常有用,了解哪些参数是定位参数或关键字参数是很重要的。
def foo(arg1, *positional, **keywords):
,则必需的位置参数可以在*positional
和**keywords
之前传递。这里的arg1
是位置参数且是必需的。请注意,回答中的位置参数表示可选的、可变数量的位置参数。 - shaffooofoo(bar=True)
,你可以使用 bar = keywords.pop('bar')
或者 bar = keywords.pop('bar', None)
来获取值。对于默认值,请使用 bar = keywords.pop('bar', False)
。 - oHo使用关键字参数与使用普通参数相同,唯一的区别是顺序不重要。例如,下面的两个函数调用是相同的:
def foo(bar, baz):
pass
foo(1, 2)
foo(baz=2, bar=1)
pow
的签名为pow(x, y, z=None, /)
,具有位置参数(参数列表中的/
表示所有前面的参数都是位置参数)。随着这个变化,pow(x=5, y=3)
会导致Traceback (most recent call last): File "<stdin>", line 1, in <module> TypeError: pow() takes no keyword arguments
。请参阅https://www.python.org/dev/peps/pep-0570/。 - joseville它们之前没有关键字。顺序很重要!
func(1,2,3, "foo")
它们在前面有关键字。它们可以以任意顺序出现!
func(foo="bar", baz=5, hello=123)
func(baz=5, foo="bar", hello=123)
你还需要知道,如果你使用默认参数并忽略插入关键字,那么顺序就很重要了!
def func(foo=1, baz=2, hello=3): ...
func("bar", 5, 123)
func("bar", 5)
?然后说明 hello
得到了它的默认值 3
。 - ToolmakerSteve有两种方法可以为函数参数分配参数值,都被使用。
按位置。 位置参数没有关键字,并首先分配。
按关键字。 关键字参数具有关键字,并在位置参数之后第二次分配。
请注意,您可以选择使用位置参数。
如果您不使用位置参数,那么 - 是的 - 您写的一切最终都将成为关键字参数。
当您调用函数时,您可以决定使用位置、关键字或混合。 如果您愿意,可以选择使用所有关键字。 我们中的一些人不会做出这个选择,而是使用位置参数。
我很惊讶没有人指出可以这样传递一个键控参数字典,满足形式参数。
>>> def func(a='a', b='b', c='c', **kwargs):
... print 'a:%s, b:%s, c:%s' % (a, b, c)
...
>>> func()
a:a, b:b, c:c
>>> func(**{'a' : 'z', 'b':'q', 'c':'v'})
a:z, b:q, c:v
>>>
**kwargs
,你的论点会更加清晰。这将证明即使在一个固定参数数量的简单函数定义中,也可以提供一个字典。也就是说,在定义中不需要任何花哨的东西。然后,你可以添加第二个例子,其中包含 **kwargs 在定义中,并展示如何通过它来获得字典中的额外项。 - ToolmakerSteveprint 'a:%s, b:%s, c:%s' % (a, b, c)
会出现语法错误,但是 print('a:%s, b:%s, c:%s' % (a, b, c))
可以正常工作。这是 Python 版本的问题吗?无论如何,感谢您提供这个见解,直到现在我一直在使用更加笨拙的 print('a:{}, b:{}, c:{}'.format(a, b, c))
。 - Axel Bregnsbo使用Python 3,您可以同时拥有必需和非必需的关键字参数:
可选: (对于参数'b'定义了默认值)
def func1(a, *, b=42):
...
func1(value_for_a) # b is optional and will default to 42
必需的(参数“b”未定义默认值):
def func2(a, *, b):
...
func2(value_for_a, b=21) # b is set to 21 by the function call
func2(value_for_a) # ERROR: missing 1 required keyword-only argument: 'b'`
如果您有许多相似的参数需要传递,特别是它们属于同一类型,那么可以使用命名参数或者创建自定义类来处理这种情况。
*args
和**kwargs
来做一些聪明的事情(从这个网站)。def test_var_kwargs(farg, **kwargs):
print "formal arg:", farg
for key in kwargs:
print "another keyword arg: %s: %s" % (key, kwargs[key])
这将允许您使用任意关键字参数,这些参数可能具有您不想事先定义的键。
我正在寻找一个使用类型注释的默认kwargs示例:
def test_var_kwarg(a: str, b: str='B', c: str='', **kwargs) -> str:
return ' '.join([a, b, c, str(kwargs)])
例子:
>>> print(test_var_kwarg('A', c='okay'))
A B okay {}
>>> d = {'f': 'F', 'g': 'G'}
>>> print(test_var_kwarg('a', c='c', b='b', **d))
a b c {'f': 'F', 'g': 'G'}
>>> print(test_var_kwarg('a', 'b', 'c'))
a b c {}
只需补充/添加一种定义函数调用时未分配关键字参数的默认值的方法:
def func(**keywargs):
if 'my_word' not in keywargs:
word = 'default_msg'
else:
word = keywargs['my_word']
return word
通过以下方式调用:
print(func())
print(func(my_word='love'))
你将获得:
default_msg
love
在Python中了解更多关于*args
和**kwargs
的知识: https://www.digitalocean.com/community/tutorials/how-to-use-args-and-kwargs-in-python-3