我以为我可以在Python 2中的函数调用中使用长度可变的位置参数之后的命名参数,但是当导入Python类时,我得到了一个SyntaxError
。我使用以下“get”方法编写,例如:
class Foo(object):
def __init__(self):
print "You have created a Foo."
def get(self, *args, raw=False, vars=None):
print len(args)
print raw
print vars
错误如下:
def get(self, *args, raw=False, vars=None):
^
SyntaxError: invalid syntax
我希望能够以多种方式调用该方法:
f = Foo()
f.get(arg1, arg2)
f.get(arg1, raw=True)
f.get(arg1, arg2, raw=True, vars=something)
等等
它确实有效,但仅在Python 3中有效。见政治公众人物3102。从浏览“最新消息”文档来看,似乎没有2.x backport,所以您运气不佳。您必须接受任何关键字参数(
**kwargs
)并手动解析它。您可以使用d.get(k, default)
来获取d[k]
或default
(如果没有)。要从kwargs
中删除参数,例如在调用超级类的方法之前,请使用d.pop
。注意,在
def get(self, *args, raw=False, vars=None):
中,raw=False
和vars=None
与关键字参数无关。这些是默认参数值。具有默认值的参数可以按位置传递,没有默认值的参数可以按关键字传递:类似地,仅关键字参数不需要有默认值。在
*args
参数之后,将它们标记为仅关键字,而不是默认值的存在:Python的语法不允许在函数和关键字参数中同时使用默认值的变量参数。如果必须有关键字参数和任意数量的位置参数,则还需要允许任意数量的关键字参数。
这是为关键字参数提供默认值以及允许任意数量的位置参数的常见模式:
如果你根本不使用额外的关键字参数,你就不用担心了。这使得函数的自文档化程度降低了一点,您可以使用正确编写的docstring来弥补这一点。
相关问题 更多 >
编程相关推荐