先前接受的答案是deprecated,截至Python 3.0。现在应该选择替代它的Signature类,而不是使用inspect.getargspec。

通过^{} function很容易为函数创建签名:from inspect import signature

def someMethod(self, arg1, kwarg1=None):

pass

sig = signature(someMethod)

现在,您可以通过str快速查看其参数:str(sig) # returns: '(self, arg1, kwarg1=None)'

或者还可以通过sig.parameters获得属性名到参数对象的映射。params = sig.parameters

print(params['kwarg1']) # prints: kwarg1=20

此外,您还可以在sig.parameters上调用len,以查看此函数所需的参数数:print(len(params)) # 3

映射params中的每个条目实际上是一个^{} object,它具有使您的生活更轻松的进一步属性。例如,抓取参数并查看其默认值现在很容易使用:kwarg1 = params['kwarg1']

kwarg1.default # returns: None

对于parameters中包含的其他对象也一样。

至于Python 2.x用户,虽然inspect.getargspec没有被弃用,但该语言很快就会被:-)。Signature类在2.x系列中不可用,也不会。因此,您仍然需要使用^{}。

至于Python2和3之间的转换,如果您的代码依赖于Python2中的getargspec接口,而在3中切换到signature则太困难,您确实有使用^{}的宝贵选项。它提供了一个类似于getargspec(单个可调用参数)的接口,以便获取函数的参数,同时还处理getargspec没有的一些附加情况:from inspect import getfullargspec


ef someMethod(self, arg1, kwarg1=None):
pass
args = getfullargspec(someMethod)
与getargspec一样,getfullargspec返回包含参数的NamedTuple。print(args)
FullArgSpec(args=['self', 'arg1', 'kwarg1'], varargs=None, varkw=None, defaults=(None,), kwonlyargs=[], kwonlydefaults=None, annotations={})