目前接受的答案是从Python 3.0的
deprecated。而不是使用inspect.getargspec,现在应该选择取代它的Signature类。
from inspect import signature
def someMethod(self, arg1, kwarg1=None):
pass
sig = signature(someMethod)
现在,您可以通过字符串快速查看其参数:
str(sig) # returns: '(self, arg1, kwarg1=None)'
或者也可以通过sig.parameters获取属性名称到参数对象的映射。
params = s.parameters
print(params['kwarg1']) # prints: kwarg1=20
此外,您可以在sig.parameters上调用len,也可以查看此函数需要的参数数量:
print(len(params)) # 3
params映射中的每个条目实际上是一个Parameter object,有进一步的属性,使你的生活更轻松。例如,抓取参数并查看其默认值现在很容易执行:
kwarg1 = params['kwarg1']
kwarg1.default # returns: None
类似地对于包含在参数中的其余对象。
对于Python 2.x用户,虽然inspect.getargspec不被弃用,该语言很快将是:-)。 Signature类在2.x系列中不可用,并且不会。
尽管如此,你确实有一个宝贵的选择使用inspect.getfullargspec提供了一个Python版本不可知的接口来抓取函数的参数。它还处理比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={})