Как получить список аргументов встроенного конструктора класса Python?

#python #reflection #inspection #asdl

#python #отражение #проверка #asdl

Вопрос:

Я пытаюсь использовать inspect модуль, однако, похоже, я не могу использовать его на встроенном (родном?) класс, иначе я неправильно понял.

Я использую Python 2.7 и попробовал с Python 3.2.

Это работает:

 >>> import inspect
>>> class C:
...     def __init__(self,a,b=4):
...         self.sum = a   b
... 
>>> inspect.getargspec(C.__init__)
ArgSpec(args=['self','a', 'b'], varargs=None, keywords=None, defaults=(4,))
  

Это не работает:

 >>> import inspect
>>> import ast
>>> inspect.getargspec(ast.If.__init__)
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
  File "/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/inspect.py", line 813, in getargspec
    raise TypeError('{!r} is not a Python function'.format(func))
TypeError: <slot wrapper '__init__' of '_ast.AST' objects> is not a Python function
  

Мне интересно, есть ли другой метод автоматического получения этих параметров?

(В моем случае я думаю об альтернативе, которая заключалась бы в анализе грамматики Python, файла ASDL, в котором объясняется, как инициализировать узлы AST, используя некоторый код, который я видел в исходном коде проекта PyPy, но мне интересно, есть ли другой способ)

Ответ №1:

Их невозможно получить, поскольку они являются свойством кода C, стоящего за функцией, а не самой функции.

Ответ №2:

Обратите внимание, что этот код отлично работает на PyPy (где на самом деле нет различия между этими двумя типами функций).

 (pypy)fijal@helmut:~$ python
class C(Python 2.7.1 (f1e873c5533d, Sep 19 2011, 02:01:57)
[PyPy 1.6.0-dev1 with GCC 4.4.3] on linux2
Type "help", "copyright", "credits" or "license" for more information.
Welcome to rlcompleter2 0.96
for nice experiences hit <tab> multiple times
And now for something completely different: ``PyPy needs a Just-in-Time JIT''
>>>> class C:
....  def __init__(self, a, b=4):
....    pass
.... 
>>>> import inspect
>>>> inspect.getargspec(C.__init__)
ArgSpec(args=['self', 'a', 'b'], varargs=None, keywords=None, defaults=(4,))
>>>>