早于接受的答案已于弃用Python 3.0
。inspect.getargspec
现在,您应该选择Signature
取代它的类,而不是使用它。
创建功能的签名是通过简单的signature
功能:
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
此外,你可以叫len
上sig.parameters
也看到的参数此功能,需要数量:
print(len(params)) # 3
params
映射中的每个条目实际上都是一个具有更多属性的Parameter
对象,使您的生活更加轻松。例如,现在可以轻松地执行以下操作来获取参数并查看其默认值:
kwarg1 = params['kwarg1']
kwarg1.default # returns: None
包含在中的其余对象也类似parameters
。
对于Python 2.x
用户,虽然inspect.getargspec
不建议弃用,但该语言很快就会成为:-)。该Signature
课程在该2.x
系列中不可用,也不会提供。因此,您仍然需要使用inspect.getargspec
。
至于Python 2和3之间的转换,如果你有一些代码依赖的接口getargspec
在Python 2切换到signature
在3
是太难了,你必须将有价值的选择使用inspect.getfullargspec
。它提供了与getargspec
(单个可调用参数)相似的接口,以获取函数的参数,同时还处理某些其他情况,这些getargspec
情况不是:
from inspect import getfullargspec
def 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={})
inspect
标准库模块就没有任何理由。