inspect
— Inspect live objects¶
Вихідний код: Lib/inspect.py
Модуль inspect
надає кілька корисних функцій, які допомагають отримати інформацію про живі об’єкти, такі як модулі, класи, методи, функції, відстеження, об’єкти фрейму та об’єкти коду. Наприклад, це може допомогти вам вивчити вміст класу, отримати вихідний код методу, витягти та відформатувати список аргументів для функції або отримати всю інформацію, необхідну для відображення детального відстеження.
Цей модуль надає чотири основні види послуг: перевірка типу, отримання вихідного коду, перевірка класів і функцій і перевірка стека інтерпретатора.
Типи та члени¶
The getmembers()
function retrieves the members of an object such as a
class or module. The functions whose names begin with «is» are mainly
provided as convenient choices for the second argument to getmembers()
.
They also help you determine when you can expect to find the following special
attributes:
Тип |
Атрибут |
опис |
---|---|---|
module |
__doc__ |
рядок документації |
__file__ |
filename (missing for built-in modules) |
|
клас |
__doc__ |
рядок документації |
__name__ |
ім’я, з яким було визначено цей клас |
|
__qualname__ |
кваліфіковане ім’я |
|
__module__ |
ім’я модуля, в якому був визначений цей клас |
|
метод |
__doc__ |
рядок документації |
__name__ |
ім’я, з яким було визначено цей метод |
|
__qualname__ |
кваліфіковане ім’я |
|
__func__ |
об’єкт функції, що містить реалізацію методу |
|
__self__ |
екземпляр, до якого прив’язаний цей метод, або |
|
__module__ |
ім’я модуля, в якому був визначений цей метод |
|
функція |
__doc__ |
рядок документації |
__name__ |
ім’я, з яким ця функція була визначена |
|
__qualname__ |
кваліфіковане ім’я |
|
__code__ |
об’єкт коду, що містить скомпільовану функцію bytecode |
|
__defaults__ |
кортеж із будь-якими значеннями за замовчуванням для позиційних або ключових параметрів |
|
__kwdefaults__ |
відображення будь-яких значень за замовчуванням для параметрів, які містять лише ключові слова |
|
__globals__ |
глобальний простір імен, у якому була визначена ця функція |
|
__annotations__ |
зіставлення назв параметрів з анотаціями; Ключ |
|
__module__ |
ім’я модуля, в якому була визначена ця функція |
|
traceback |
tb_frame |
кадрувати об’єкт на цьому рівні |
tb_lasti |
індекс останньої спроби вказівки в байт-коді |
|
tb_lineno |
номер поточного рядка у вихідному коді Python |
|
tb_next |
наступний внутрішній об’єкт трасування (викликається цим рівнем) |
|
frame |
f_back |
наступний зовнішній об’єкт фрейму (виклик цього фрейму) |
f_builtins |
вбудований простір імен, видимий цим фреймом |
|
f_code |
об’єкт коду, який виконується в цьому кадрі |
|
f_globals |
глобальний простір імен, видимий цим кадром |
|
f_lasti |
індекс останньої спроби вказівки в байт-коді |
|
f_lineno |
номер поточного рядка у вихідному коді Python |
|
f_locals |
локальний простір імен, видимий цим кадром |
|
f_trace |
функція трасування для цього кадру або |
|
код |
co_argcount |
кількість аргументів (не враховуючи лише аргументи ключового слова, * або ** аргументи) |
co_code |
рядок необробленого скомпільованого байт-коду |
|
co_cellvars |
кортеж імен змінних комірки (на які посилаються області, що містять) |
|
co_conts |
кортеж констант, що використовуються в байт-коді |
|
co_filename |
ім’я файлу, в якому створено цей об’єкт коду |
|
co_firstlineno |
номер першого рядка у вихідному коді Python |
|
co_flags |
растрова карта прапорів |
|
co_lnotab |
кодоване відображення номерів рядків в індекси байт-коду |
|
co_freevars |
кортеж імен вільних змінних (на які посилаються через закриття функції) |
|
co_posonlyargcount |
кількість лише позиційних аргументів |
|
co_kwonlyargcount |
кількість аргументів лише для ключових слів (не враховуючи аргумент **) |
|
co_name |
ім’я, з яким було визначено цей об’єкт коду |
|
co_names |
tuple of names of local variables |
|
co_nlocals |
кількість локальних змінних |
|
co_stacksize |
необхідний простір у стеку віртуальної машини |
|
co_varnames |
кортеж імен аргументів і локальних змінних |
|
generator |
__name__ |
name |
__qualname__ |
кваліфіковане ім’я |
|
gi_frame |
frame |
|
gi_running |
чи працює генератор? |
|
gi_code |
код |
|
gi_yieldfrom |
об’єкт повторюється за допомогою |
|
coroutine |
__name__ |
name |
__qualname__ |
кваліфіковане ім’я |
|
cr_await |
об’єкт, який очікується, або |
|
cr_frame |
frame |
|
cr_running |
чи виконується співпрограма? |
|
cr_code |
код |
|
cr_origin |
де була створена співпрограма, або |
|
builtin |
__doc__ |
рядок документації |
__name__ |
оригінальна назва цієї функції або методу |
|
__qualname__ |
кваліфіковане ім’я |
|
__self__ |
екземпляр, до якого прив’язаний метод, або |
Змінено в версії 3.5: Додайте атрибути __qualname__
і gi_yieldfrom
до генераторів.
Атрибут __name__
генераторів тепер встановлюється з імені функції, а не з кодового імені, і тепер його можна змінювати.
Змінено в версії 3.7: Додайте атрибут cr_origin
до співпрограм.
-
inspect.
getmembers
(object[, predicate])¶ Повертає всі члени об’єкта в списку пар
(ім’я, значення)
, відсортованих за назвою. Якщо вказано необов’язковий аргумент предикат, який буде викликано з об’єктомзначення
кожного члена, будуть включені лише ті члени, для яких предикат повертає справжнє значення.Примітка
getmembers()
will only return class attributes defined in the metaclass when the argument is a class and those attributes have been listed in the metaclass“ custom__dir__()
.
-
inspect.
getmodulename
(path)¶ Повертає ім’я модуля, названого шляхом до файлу, без назв пакетів, що входять до нього. Розширення файлу перевіряється на всі записи в
importlib.machinery.all_suffixes()
. Якщо він збігається, остаточний компонент шляху повертається з видаленим розширенням. В іншому випадку повертаєтьсяNone
.Зауважте, що ця функція тільки повертає значущу назву для фактичних модулів Python - шляхи, які потенційно посилаються на пакети Python, все одно повертатимуть
None
.Змінено в версії 3.3: Функція базується безпосередньо на
importlib
.
-
inspect.
ismodule
(object)¶ Повертає
True
, якщо об’єкт є модулем.
-
inspect.
isclass
(object)¶ Повертає
True
, якщо об’єкт є класом, вбудованим чи створеним у коді Python.
-
inspect.
ismethod
(object)¶ Повертає
True
, якщо об’єкт є зв’язаним методом, написаним на Python.
-
inspect.
isfunction
(object)¶ Повертає
True
, якщо об’єкт є функцією Python, яка включає функції, створені виразом lambda.
-
inspect.
isgeneratorfunction
(object)¶ Повертає
True
, якщо об’єкт є функцією генератора Python.Змінено в версії 3.8: Функції, загорнуті в
functools.partial()
, тепер повертаютьTrue
, якщо загорнута функція є функцією генератора Python.
-
inspect.
isgenerator
(object)¶ Повертає
True
, якщо об’єкт є генератором.
-
inspect.
iscoroutinefunction
(object)¶ Return
True
if the object is a coroutine function (a function defined with anasync def
syntax).Нове в версії 3.5.
Змінено в версії 3.8: Функції, загорнуті в
functools.partial()
, тепер повертаютьTrue
, якщо загорнута функція є coroutine function.
-
inspect.
iscoroutine
(object)¶ Повертає
True
, якщо об’єкт є coroutine, створеною функцієюasync def
.Нове в версії 3.5.
-
inspect.
isawaitable
(object)¶ Повертає
True
, якщо об’єкт можна використовувати у виразіawait
.Can also be used to distinguish generator-based coroutines from regular generators:
def gen(): yield @types.coroutine def gen_coro(): yield assert not isawaitable(gen()) assert isawaitable(gen_coro())
Нове в версії 3.5.
-
inspect.
isasyncgenfunction
(object)¶ Return
True
if the object is an asynchronous generator function, for example:>>> async def agen(): ... yield 1 ... >>> inspect.isasyncgenfunction(agen) True
Нове в версії 3.6.
Змінено в версії 3.8: Functions wrapped in
functools.partial()
now returnTrue
if the wrapped function is a asynchronous generator function.
-
inspect.
isasyncgen
(object)¶ Повертає
True
, якщо об’єкт є asynchronous generator iterator, створеним функцією asynchronous generator.Нове в версії 3.6.
-
inspect.
istraceback
(object)¶ Повертає
True
, якщо об’єкт є трасуванням.
-
inspect.
isframe
(object)¶ Повертає
True
, якщо об’єкт є фреймом.
-
inspect.
iscode
(object)¶ Повертає
True
, якщо об’єкт є кодом.
-
inspect.
isbuiltin
(object)¶ Повертає
True
, якщо об’єкт є вбудованою функцією або зв’язаним вбудованим методом.
-
inspect.
isroutine
(object)¶ Повертає
True
, якщо об’єкт є визначеною користувачем або вбудованою функцією чи методом.
-
inspect.
isabstract
(object)¶ Повертає
True
, якщо об’єкт є абстрактним базовим класом.
-
inspect.
ismethoddescriptor
(object)¶ Повертає
True
, якщо об’єкт є дескриптором методу, але не якщоismethod()
,isclass()
,isfunction()
абоisbuiltin()
є істинними.This, for example, is true of
int.__add__
. An object passing this test has a__get__()
method but not a__set__()
method, but beyond that the set of attributes varies. A__name__
attribute is usually sensible, and__doc__
often is.Methods implemented via descriptors that also pass one of the other tests return
False
from theismethoddescriptor()
test, simply because the other tests promise more – you can, e.g., count on having the__func__
attribute (etc) when an object passesismethod()
.
-
inspect.
isdatadescriptor
(object)¶ Повертає
True
, якщо об’єкт є дескриптором даних.Data descriptors have a
__set__
or a__delete__
method. Examples are properties (defined in Python), getsets, and members. The latter two are defined in C and there are more specific tests available for those types, which is robust across Python implementations. Typically, data descriptors will also have__name__
and__doc__
attributes (properties, getsets, and members have both of these attributes), but this is not guaranteed.
-
inspect.
isgetsetdescriptor
(object)¶ Повертає
True
, якщо об’єкт є дескриптором getset.CPython implementation detail: getsets — це атрибути, визначені в модулях розширення за допомогою структур
PyGetSetDef
. Для реалізацій Python без таких типів цей метод завжди повертатимеFalse
.
-
inspect.
ismemberdescriptor
(object)¶ Повертає
True
, якщо об’єкт є дескриптором-членом.CPython implementation detail: Дескриптори членів — це атрибути, визначені в модулях розширення за допомогою структур
PyMemberDef
. Для реалізацій Python без таких типів цей метод завжди повертатимеFalse
.
Отримання вихідного коду¶
-
inspect.
getdoc
(object)¶ Get the documentation string for an object, cleaned up with
cleandoc()
. If the documentation string for an object is not provided and the object is a class, a method, a property or a descriptor, retrieve the documentation string from the inheritance hierarchy.Змінено в версії 3.5: Рядки документації тепер успадковуються, якщо не перевизначаються.
-
inspect.
getcomments
(object)¶ Повертайте в одному рядку будь-які рядки коментарів безпосередньо перед вихідним кодом об’єкта (для класу, функції чи методу) або у верхній частині вихідного файлу Python (якщо об’єкт є модулем). Якщо вихідний код об’єкта недоступний, поверніть
None
. Це може статися, якщо об’єкт було визначено в C або інтерактивній оболонці.
-
inspect.
getfile
(object)¶ Повертає ім’я (текстового або бінарного) файлу, у якому було визначено об’єкт. Це не вдасться з помилкою
TypeError
, якщо об’єкт є вбудованим модулем, класом або функцією.
-
inspect.
getmodule
(object)¶ Try to guess which module an object was defined in.
-
inspect.
getsourcefile
(object)¶ Return the name of the Python source file in which an object was defined. This will fail with a
TypeError
if the object is a built-in module, class, or function.
-
inspect.
getsourcelines
(object)¶ Return a list of source lines and starting line number for an object. The argument may be a module, class, method, function, traceback, frame, or code object. The source code is returned as a list of the lines corresponding to the object and the line number indicates where in the original source file the first line of code was found. An
OSError
is raised if the source code cannot be retrieved.
-
inspect.
getsource
(object)¶ Return the text of the source code for an object. The argument may be a module, class, method, function, traceback, frame, or code object. The source code is returned as a single string. An
OSError
is raised if the source code cannot be retrieved.
-
inspect.
cleandoc
(doc)¶ Очистіть відступи з рядків документів, які мають відступ, щоб вирівнюватися з блоками коду.
Усі початкові пробіли видаляються з першого рядка. Усі пробіли на початку, які можна рівномірно видалити з другого рядка, видаляються. Порожні рядки на початку та в кінці згодом видаляються. Крім того, усі вкладки розгортаються до пробілів.
Самоаналіз викликаних за допомогою об’єкта Signature¶
Нове в версії 3.3.
The Signature object represents the call signature of a callable object and its
return annotation. To retrieve a Signature object, use the signature()
function.
-
inspect.
signature
(callable, *, follow_wrapped=True)¶ Return a
Signature
object for the givencallable
:>>> from inspect import signature >>> def foo(a, *, b:int, **kwargs): ... pass >>> sig = signature(foo) >>> str(sig) '(a, *, b:int, **kwargs)' >>> str(sig.parameters['b']) 'b:int' >>> sig.parameters['b'].annotation <class 'int'>
Приймає широкий діапазон викликів Python, від простих функцій і класів до об’єктів
functools.partial()
.Raises
ValueError
if no signature can be provided, andTypeError
if that type of object is not supported.Слеш (/) у сигнатурі функції означає, що параметри перед нею є лише позиційними. Для отримання додаткової інформації див. запис у поширених питаннях щодо позиційних параметрів.
Нове в версії 3.5:
follow_wrapped
parameter. PassFalse
to get a signature ofcallable
specifically (callable.__wrapped__
will not be used to unwrap decorated callables.)Примітка
Деякі виклики можуть бути недоступними для інтроспекції в певних реалізаціях Python. Наприклад, у CPython деякі вбудовані функції, визначені в C, не надають метаданих про свої аргументи.
-
class
inspect.
Signature
(parameters=None, *, return_annotation=Signature.empty)¶ A Signature object represents the call signature of a function and its return annotation. For each parameter accepted by the function it stores a
Parameter
object in itsparameters
collection.Необов’язковий аргумент parameters — це послідовність об’єктів
Parameter
, яка перевіряється, щоб перевірити, чи немає параметрів із повторюваними іменами та чи параметри розташовано в правильному порядку, тобто спочатку лише позиційні, а потім позиційні -or-keyword, і що параметри зі значеннями за замовчуванням слідують за параметрами без значень за замовчуванням.The optional return_annotation argument, can be an arbitrary Python object, is the «return» annotation of the callable.
Signature objects are immutable. Use
Signature.replace()
to make a modified copy.Змінено в версії 3.5: Signature objects are picklable and hashable.
-
empty
¶ Спеціальний маркер рівня класу, щоб вказати відсутність анотації повернення.
-
parameters
¶ Впорядковане зіставлення назв параметрів із відповідними об’єктами
Parameter
. Параметри відображаються в строгому порядку визначення, включаючи параметри лише ключових слів.Змінено в версії 3.7: Python лише явно гарантував, що він зберіг порядок оголошення параметрів лише за ключовими словами, починаючи з версії 3.7, хоча на практиці цей порядок завжди зберігався в Python 3.
-
return_annotation
¶ Анотація «повернення» для викликаного. Якщо викликаний не має анотації «повернення», цей атрибут має значення
Signature.empty
.
-
bind
(*args, **kwargs)¶ Створіть відображення позиційних аргументів і аргументів ключових слів на параметри. Повертає
BoundArguments
, якщо*args
і**kwargs
збігаються з підписом, або викликаєTypeError
.
-
bind_partial
(*args, **kwargs)¶ Працює так само, як
Signature.bind()
, але дозволяє пропускати деякі необхідні аргументи (імітує поведінкуfunctools.partial()
). ПовертаєBoundArguments
або викликаєTypeError
, якщо передані аргументи не збігаються з підписом.
-
replace
(*[, parameters][, return_annotation])¶ Create a new Signature instance based on the instance replace was invoked on. It is possible to pass different
parameters
and/orreturn_annotation
to override the corresponding properties of the base signature. To remove return_annotation from the copied Signature, pass inSignature.empty
.>>> def test(a, b): ... pass >>> sig = signature(test) >>> new_sig = sig.replace(return_annotation="new return anno") >>> str(new_sig) "(a, b) -> 'new return anno'"
-
classmethod
from_callable
(obj, *, follow_wrapped=True)¶ Return a
Signature
(or its subclass) object for a given callableobj
. Passfollow_wrapped=False
to get a signature ofobj
without unwrapping its__wrapped__
chain.This method simplifies subclassing of
Signature
:class MySignature(Signature): pass sig = MySignature.from_callable(min) assert isinstance(sig, MySignature)
Нове в версії 3.5.
-
-
class
inspect.
Parameter
(name, kind, *, default=Parameter.empty, annotation=Parameter.empty)¶ Parameter objects are immutable. Instead of modifying a Parameter object, you can use
Parameter.replace()
to create a modified copy.Змінено в версії 3.5: Parameter objects are picklable and hashable.
-
empty
¶ Спеціальний маркер рівня класу для визначення відсутності значень за замовчуванням і приміток.
-
name
¶ Ім’я параметра у вигляді рядка. Ім’я має бути дійсним ідентифікатором Python.
CPython implementation detail: CPython генерує неявні імена параметрів у формі
.0
для об’єктів коду, які використовуються для реалізації розуміння та виразів генератора.Змінено в версії 3.6: These parameter names are exposed by this module as names like
implicit0
.
-
default
¶ Стандартне значення для параметра. Якщо параметр не має значення за замовчуванням, цей атрибут має значення
Parameter.empty
.
-
annotation
¶ Анотація до параметра. Якщо параметр не має анотації, цей атрибут має значення
Parameter.empty
.
-
kind
¶ Describes how argument values are bound to the parameter. Possible values (accessible via
Parameter
, likeParameter.KEYWORD_ONLY
):Ім’я
Значення
ПОЗИЦІЙНЕ_ЛИШЕ
Значення має бути надано як позиційний аргумент. Лише позиційні параметри – це ті, які з’являються перед записом
/
(якщо він є) у визначенні функції Python.POSITIONAL_OR_KEYWORD
Значення може бути надано як ключове слово або позиційний аргумент (це стандартна поведінка зв’язування для функцій, реалізованих у Python).
VAR_POSITIONAL
Кортеж позиційних аргументів, які не прив’язані до жодного іншого параметра. Це відповідає параметру
*args
у визначенні функції Python.KEYWORD_ONLY
Значення має бути надано як аргумент ключового слова. Параметри лише для ключових слів – це ті, які з’являються після запису
*
або*args
у визначенні функції Python.VAR_KEYWORD
Набір аргументів ключових слів, які не прив’язані до жодного іншого параметра. Це відповідає параметру
**kwargs
у визначенні функції Python.Example: print all keyword-only arguments without default values:
>>> def foo(a, b, *, c, d=10): ... pass >>> sig = signature(foo) >>> for param in sig.parameters.values(): ... if (param.kind == param.KEYWORD_ONLY and ... param.default is param.empty): ... print('Parameter:', param) Parameter: c
-
kind.
description
¶ Describes a enum value of Parameter.kind.
Нове в версії 3.8.
Example: print all descriptions of arguments:
>>> def foo(a, b, *, c, d=10): ... pass >>> sig = signature(foo) >>> for param in sig.parameters.values(): ... print(param.kind.description) positional or keyword positional or keyword keyword-only keyword-only
-
replace
(*[, name][, kind][, default][, annotation])¶ Create a new Parameter instance based on the instance replaced was invoked on. To override a
Parameter
attribute, pass the corresponding argument. To remove a default value or/and an annotation from a Parameter, passParameter.empty
.>>> from inspect import Parameter >>> param = Parameter('foo', Parameter.KEYWORD_ONLY, default=42) >>> str(param) 'foo=42' >>> str(param.replace()) # Will create a shallow copy of 'param' 'foo=42' >>> str(param.replace(default=Parameter.empty, annotation='spam')) "foo:'spam'"
Змінено в версії 3.4: In Python 3.3 Parameter objects were allowed to have
name
set toNone
if theirkind
was set toPOSITIONAL_ONLY
. This is no longer permitted.-
-
class
inspect.
BoundArguments
¶ Результат виклику
Signature.bind()
абоSignature.bind_partial()
. Зберігає відображення аргументів у параметри функції.-
arguments
¶ Змінне відображення імен параметрів у значеннях аргументів. Містить лише явно пов’язані аргументи. Зміни в
arguments
відображатимуться вargs
іkwargs
.Слід використовувати разом із
Signature.parameters
для будь-яких цілей обробки аргументів.Примітка
Аргументи, для яких
Signature.bind()
абоSignature.bind_partial()
покладалися на значення за замовчуванням, пропускаються. Однак, якщо потрібно, використовуйтеBoundArguments.apply_defaults()
, щоб додати їх.Змінено в версії 3.9:
arguments
тепер має типdict
. Раніше він мав типcollections.OrderedDict
.
-
apply_defaults
()¶ Установіть значення за замовчуванням для відсутніх аргументів.
Для змінних позиційних аргументів (
*args
) за умовчанням є порожній кортеж.Для аргументів зі змінними ключовими словами (
**kwargs
) типовим є порожній dict.>>> def foo(a, b='ham', *args): pass >>> ba = inspect.signature(foo).bind('spam') >>> ba.apply_defaults() >>> ba.arguments {'a': 'spam', 'b': 'ham', 'args': ()}
Нове в версії 3.5.
The
args
andkwargs
properties can be used to invoke functions:def test(a, *, b): ... sig = signature(test) ba = sig.bind(10, b=20) test(*ba.args, **ba.kwargs)
-
Дивись також
- PEP 362 - Об’єкт підпису функції.
Детальна специфікація, деталі реалізації та приклади.
Класи та функції¶
-
inspect.
getclasstree
(classes, unique=False)¶ Упорядкуйте заданий список класів у ієрархію вкладених списків. Там, де з’являється вкладений список, він містить класи, похідні від класу, запис якого безпосередньо передує списку. Кожен запис є 2-кортежем, що містить клас і кортеж його базових класів. Якщо аргумент unique є істинним, у поверненій структурі з’являється рівно один запис для кожного класу в заданому списку. В іншому випадку класи, які використовують множинне успадкування, та їхні нащадки з’являтимуться кілька разів.
-
inspect.
getargspec
(func)¶ Get the names and default values of a Python function’s parameters. A named tuple
ArgSpec(args, varargs, keywords, defaults)
is returned. args is a list of the parameter names. varargs and keywords are the names of the*
and**
parameters orNone
. defaults is a tuple of default argument values orNone
if there are no default arguments; if this tuple has n elements, they correspond to the last n elements listed in args.Застаріло починаючи з версії 3.0: Use
getfullargspec()
for an updated API that is usually a drop-in replacement, but also correctly handles function annotations and keyword-only parameters.Alternatively, use
signature()
and Signature Object, which provide a more structured introspection API for callables.
-
inspect.
getfullargspec
(func)¶ Отримати імена та значення за замовчуванням параметрів функції Python. Повертається named tuple:
FullArgSpec(args, varargs, varkw, defaults, kwonlyargs, kwonlydefaults, анотації)
args — це список імен позиційних параметрів. varargs — це назва параметра
*
абоNone
, якщо довільні позиційні аргументи не приймаються. varkw — це назва параметра**
абоNone
, якщо довільні аргументи ключового слова не приймаються. defaults — це n-кортеж значень аргументів за замовчуванням, що відповідають останнім n позиційним параметрам, абоNone
, якщо такі значення за замовчуванням не визначено. kwonlyargs — це список імен параметрів лише за ключовими словами в порядку оголошення. kwonlydefaults — це словник, який зіставляє назви параметрів з kwonlyargs на значення за замовчуванням, які використовуються, якщо аргумент не надано. анотації — це словник, який зіставляє назви параметрів з анотаціями. Спеціальний ключ"return"
використовується для повідомлення анотації значення, що повертається функцією (якщо є).Зауважте, що
signature()
і Signature Object надають рекомендований API для інтроспекції з можливістю виклику та підтримують додаткові режими (наприклад, лише позиційні аргументи), які іноді зустрічаються в API модуля розширення. Ця функція зберігається головним чином для використання в коді, який потребує підтримки сумісності з API модуляinspect
Python 2.Змінено в версії 3.4: Ця функція тепер базується на
signature()
, але все ще ігнорує атрибути__wrapped__
і включає вже зв’язаний перший параметр у вихідні дані підпису для зв’язаних методів.Змінено в версії 3.6: Раніше цей метод був задокументований як застарілий на користь
signature()
у Python 3.5, але це рішення було скасовано, щоб відновити чітко підтримуваний стандартний інтерфейс для єдиного вихідного коду Python 2/3, що переходить із застарілої версіїgetargspec()
API.Змінено в версії 3.7: Python лише явно гарантував, що він зберіг порядок оголошення параметрів лише за ключовими словами, починаючи з версії 3.7, хоча на практиці цей порядок завжди зберігався в Python 3.
-
inspect.
getargvalues
(frame)¶ Отримати інформацію про аргументи, передані в певний кадр. Повертається named tuple
ArgInfo(args, varargs, keywords, locals)
. args — це список імен аргументів. varargs і keywords — це імена аргументів*
і**
абоNone
. locals — це словник місцевих значень даного кадру.Примітка
Ця функція була випадково позначена як застаріла в Python 3.5.
-
inspect.
formatargspec
(args[, varargs, varkw, defaults, kwonlyargs, kwonlydefaults, annotations[, formatarg, formatvarargs, formatvarkw, formatvalue, formatreturns, formatannotations]])¶ Format a pretty argument spec from the values returned by
getfullargspec()
.The first seven arguments are (
args
,varargs
,varkw
,defaults
,kwonlyargs
,kwonlydefaults
,annotations
).The other six arguments are functions that are called to turn argument names,
*
argument name,**
argument name, default values, return annotation and individual annotations into strings, respectively.For example:
>>> from inspect import formatargspec, getfullargspec >>> def f(a: int, b: float): ... pass ... >>> formatargspec(*getfullargspec(f)) '(a: int, b: float)'
Застаріло починаючи з версії 3.5: Use
signature()
and Signature Object, which provide a better introspecting API for callables.
-
inspect.
formatargvalues
(args[, varargs, varkw, locals, formatarg, formatvarargs, formatvarkw, formatvalue])¶ Відформатуйте гарну специфікацію аргументу з чотирьох значень, які повертає
getargvalues()
. Аргументи format* — це відповідні додаткові функції форматування, які викликаються для перетворення імен і значень у рядки.Примітка
Ця функція була випадково позначена як застаріла в Python 3.5.
-
inspect.
getmro
(cls)¶ Повертає кортеж базових класів класу cls, включаючи cls, у порядку вирішення методів. Жоден клас не з’являється більше одного разу в цьому кортежі. Зауважте, що порядок вирішення методів залежить від типу cls. Якщо не використовується дуже специфічний метатип, визначений користувачем, cls буде першим елементом кортежу.
-
inspect.
getcallargs
(func, /, *args, **kwds)¶ Bind the args and kwds to the argument names of the Python function or method func, as if it was called with them. For bound methods, bind also the first argument (typically named
self
) to the associated instance. A dict is returned, mapping the argument names (including the names of the*
and**
arguments, if any) to their values from args and kwds. In case of invoking func incorrectly, i.e. wheneverfunc(*args, **kwds)
would raise an exception because of incompatible signature, an exception of the same type and the same or similar message is raised. For example:>>> from inspect import getcallargs >>> def f(a, b=1, *pos, **named): ... pass >>> getcallargs(f, 1, 2, 3) == {'a': 1, 'named': {}, 'b': 2, 'pos': (3,)} True >>> getcallargs(f, a=2, x=4) == {'a': 2, 'named': {'x': 4}, 'b': 1, 'pos': ()} True >>> getcallargs(f) Traceback (most recent call last): ... TypeError: f() missing 1 required positional argument: 'a'
Нове в версії 3.2.
Застаріло починаючи з версії 3.5: Замість цього використовуйте
Signature.bind()
іSignature.bind_partial()
.
-
inspect.
getclosurevars
(func)¶ Отримайте зіставлення зовнішніх посилань на імена у функції або методі Python func на їхні поточні значення. Повертається named tuple
ClosureVars(nonlocals, globals, builtins, unbound)
. nonlocals відображає назви посилань на лексичні змінні закриття, globals на глобальні модулі функції та builtins на вбудовані елементи, видимі з тіла функції. unbound — це набір імен, на які посилається функція, які взагалі не можуть бути розпізнані з урахуванням поточних глобальних і вбудованих модулів.TypeError
виникає, якщо func не є функцією або методом Python.Нове в версії 3.3.
-
inspect.
unwrap
(func, *, stop=None)¶ Оберніть об’єкт за допомогою func. Він слідує за ланцюжком атрибутів
__wrapped__
, повертаючи останній об’єкт у ланцюжку.stop — необов’язковий зворотний виклик, який приймає об’єкт у ланцюжку оболонки як єдиний аргумент, який дозволяє розгортання завершувати достроково, якщо зворотний виклик повертає справжнє значення. Якщо зворотний виклик ніколи не повертає справжнє значення, останній об’єкт у ланцюжку повертається, як зазвичай. Наприклад,
signature()
використовує це, щоб зупинити розгортання, якщо будь-який об’єкт у ланцюжку має визначений атрибут__signature__
.ValueError
виникає, якщо зустрічається цикл.Нове в версії 3.4.
Стек інтерпретатора¶
When the following functions return «frame records,» each record is a
named tuple
FrameInfo(frame, filename, lineno, function, code_context, index)
.
The tuple contains the frame object, the filename, the line number of the
current line,
the function name, a list of lines of context from the source code, and the
index of the current line within that list.
Змінено в версії 3.5: Return a named tuple instead of a tuple.
Примітка
Зберігання посилань на об’єкти фрейму, які знаходяться в першому елементі фреймових записів, які повертаються цими функціями, може призвести до того, що ваша програма створить цикли посилань. Після створення еталонного циклу тривалість життя всіх об’єктів, до яких можна отримати доступ з об’єктів, що утворюють цикл, може стати набагато довшим, навіть якщо ввімкнено додатковий детектор циклу Python. Якщо такі цикли необхідно створити, важливо переконатися, що вони явно розірвані, щоб уникнути затримки руйнування об’єктів і збільшення споживання пам’яті, яке відбувається.
Хоча детектор циклу вловить їх, знищення кадрів (та локальних змінних) можна зробити детермінованим, видаливши цикл у реченні finally
. Це також важливо, якщо детектор циклу було вимкнено під час компіляції Python або використання gc.disable()
. Наприклад:
def handle_stackframe_without_leak():
frame = inspect.currentframe()
try:
# do something with the frame
finally:
del frame
Якщо ви хочете зберегти фрейм (наприклад, щоб пізніше надрукувати трасування), ви також можете розірвати цикли посилань за допомогою методу frame.clear()
.
Необов’язковий аргумент context, який підтримується більшістю цих функцій, визначає кількість рядків контексту для повернення, які розташовані навколо поточного рядка.
-
inspect.
getframeinfo
(frame, context=1)¶ Get information about a frame or traceback object. A named tuple
Traceback(filename, lineno, function, code_context, index)
is returned.
-
inspect.
getouterframes
(frame, context=1)¶ Get a list of frame records for a frame and all outer frames. These frames represent the calls that lead to the creation of frame. The first entry in the returned list represents frame; the last entry represents the outermost call on frame’s stack.
Змінено в версії 3.5: Повертається список іменованих кортежів
FrameInfo(frame, filename, lineno, function, code_context, index)
повертається.
-
inspect.
getinnerframes
(traceback, context=1)¶ Get a list of frame records for a traceback’s frame and all inner frames. These frames represent calls made as a consequence of frame. The first entry in the list represents traceback; the last entry represents where the exception was raised.
Змінено в версії 3.5: Повертається список іменованих кортежів
FrameInfo(frame, filename, lineno, function, code_context, index)
повертається.
-
inspect.
currentframe
()¶ Повертає об’єкт кадру для кадру стека абонента.
CPython implementation detail: Ця функція покладається на підтримку фрейму стека Python в інтерпретаторі, який не гарантовано існує в усіх реалізаціях Python. Якщо ця функція працює в реалізації без підтримки фрейму стека Python, ця функція повертає
None
.
-
inspect.
stack
(context=1)¶ Return a list of frame records for the caller’s stack. The first entry in the returned list represents the caller; the last entry represents the outermost call on the stack.
Змінено в версії 3.5: Повертається список іменованих кортежів
FrameInfo(frame, filename, lineno, function, code_context, index)
повертається.
-
inspect.
trace
(context=1)¶ Return a list of frame records for the stack between the current frame and the frame in which an exception currently being handled was raised in. The first entry in the list represents the caller; the last entry represents where the exception was raised.
Змінено в версії 3.5: Повертається список іменованих кортежів
FrameInfo(frame, filename, lineno, function, code_context, index)
повертається.
Отримання атрибутів статично¶
Both getattr()
and hasattr()
can trigger code execution when
fetching or checking for the existence of attributes. Descriptors, like
properties, will be invoked and __getattr__()
and __getattribute__()
may be called.
У випадках, коли вам потрібен пасивний самоаналіз, наприклад інструменти документування, це може бути незручно. getattr_static()
має такий самий підпис, як і getattr()
, але уникає виконання коду, коли він отримує атрибути.
-
inspect.
getattr_static
(obj, attr, default=None)¶ Retrieve attributes without triggering dynamic lookup via the descriptor protocol,
__getattr__()
or__getattribute__()
.Примітка: ця функція може бути не в змозі отримати всі атрибути, які getattr може отримати (наприклад, динамічно створені атрибути), і може знайти атрибути, які getattr не може отримати (наприклад, дескриптори, які викликають AttributeError). Він також може повертати об’єкти дескрипторів замість членів екземпляра.
Якщо примірник
__dict__
затінений іншим членом (наприклад, властивістю), тоді ця функція не зможе знайти члени примірника.Нове в версії 3.2.
getattr_static()
не розпізнає дескриптори, наприклад, дескриптори слотів або дескриптори getset в об’єктах, реалізованих у C. Об’єкт дескриптора повертається замість основного атрибута.
Ви можете впоратися з цим за допомогою такого коду. Зауважте, що виклик довільних дескрипторів getset може ініціювати виконання коду:
# example code for resolving the builtin descriptor types
class _foo:
__slots__ = ['foo']
slot_descriptor = type(_foo.foo)
getset_descriptor = type(type(open(__file__)).name)
wrapper_descriptor = type(str.__dict__['__add__'])
descriptor_types = (slot_descriptor, getset_descriptor, wrapper_descriptor)
result = getattr_static(some_object, 'foo')
if type(result) in descriptor_types:
try:
result = result.__get__()
except AttributeError:
# descriptors can raise AttributeError to
# indicate there is no underlying value
# in which case the descriptor itself will
# have to do
pass
Current State of Generators and Coroutines¶
Під час реалізації планувальників співпрограм та для інших розширених застосувань генераторів корисно визначити, чи генератор зараз виконується, очікує на запуск, відновлення чи виконання, чи вже завершив роботу. getgeneratorstate()
дозволяє легко визначити поточний стан генератора.
-
inspect.
getgeneratorstate
(generator)¶ Отримати поточний стан генератора-ітератора.
- Можливі стани:
GEN_CREATED: Очікування на початок виконання.
GEN_RUNNING: наразі виконується інтерпретатором.
GEN_SUSPENDED: наразі призупинено на виразі yield.
GEN_CLOSED: виконання завершено.
Нове в версії 3.2.
-
inspect.
getcoroutinestate
(coroutine)¶ Отримати поточний стан об’єкта співпрограми. Функція призначена для використання з об’єктами співпрограми, створеними функціями
async def
, але вона приймає будь-який об’єкт, подібний до співпрограми, який має атрибутиcr_running
іcr_frame
.- Можливі стани:
CORO_CREATED: Очікування на початок виконання.
CORO_RUNNING: наразі виконується інтерпретатором.
CORO_SUSPENDED: наразі призупинено через вираз очікування.
CORO_CLOSED: виконання завершено.
Нове в версії 3.5.
Також можна запитати поточний внутрішній стан генератора. Це здебільшого корисно для цілей тестування, щоб переконатися, що внутрішній стан оновлюється належним чином:
-
inspect.
getgeneratorlocals
(generator)¶ Отримайте зіставлення поточних локальних змінних у генераторі з їхніми поточними значеннями. Повертається словник, який відображає імена змінних на значення. Це еквівалент виклику
locals()
у тілі генератора, і застосовуються всі ті самі застереження.Якщо generator є generator без пов’язаного фрейму, повертається порожній словник.
TypeError
виникає, якщо generator не є об’єктом генератора Python.CPython implementation detail: Ця функція покладається на те, що генератор відкриває фрейм стека Python для самоаналізу, що не гарантовано буде у всіх реалізаціях Python. У таких випадках ця функція завжди повертатиме порожній словник.
Нове в версії 3.3.
-
inspect.
getcoroutinelocals
(coroutine)¶ Ця функція аналогічна
getgeneratorlocals()
, але працює для об’єктів співпрограми, створених функціямиasync def
.Нове в версії 3.5.
Кодові об’єкти Бітові прапорці¶
Python code objects have a co_flags
attribute, which is a bitmap of
the following flags:
-
inspect.
CO_OPTIMIZED
¶ Об’єкт коду оптимізовано за допомогою швидких локальних кодів.
-
inspect.
CO_NEWLOCALS
¶ If set, a new dict will be created for the frame’s
f_locals
when the code object is executed.
-
inspect.
CO_VARARGS
¶ Об’єкт коду має змінний позиційний параметр (
*args
).
-
inspect.
CO_VARKEYWORDS
¶ Об’єкт коду має змінний параметр ключового слова (
**kwargs
-like).
-
inspect.
CO_NESTED
¶ Прапорець встановлюється, коли об’єкт коду є вкладеною функцією.
-
inspect.
CO_GENERATOR
¶ Прапорець встановлюється, коли об’єкт коду є функцією генератора, тобто об’єкт генератора повертається під час виконання об’єкта коду.
-
inspect.
CO_NOFREE
¶ The flag is set if there are no free or cell variables.
-
inspect.
CO_COROUTINE
¶ Прапор встановлюється, коли об’єкт коду є співпрограмою. Коли об’єкт коду виконується, він повертає об’єкт співпрограми. Дивіться PEP 492 для більш детальної інформації.
Нове в версії 3.5.
-
inspect.
CO_ITERABLE_COROUTINE
¶ Прапор використовується для перетворення генераторів у співпрограми на основі генератора. Об’єкти-генератори з цим прапорцем можна використовувати у виразі
очікування
і можутьпоступати від
об’єктів співпрограми. Дивіться PEP 492 для більш детальної інформації.Нове в версії 3.5.
-
inspect.
CO_ASYNC_GENERATOR
¶ Прапорець встановлюється, коли об’єкт коду є функцією асинхронного генератора. Коли об’єкт коду виконується, він повертає об’єкт асинхронного генератора. Дивіться PEP 525 для більш детальної інформації.
Нове в версії 3.6.
Примітка
Прапори є специфічними для CPython і можуть не бути визначені в інших реалізаціях Python. Крім того, прапори є деталями реалізації, і їх можна видалити або застаріти в майбутніх випусках Python. Рекомендовано використовувати загальнодоступні API з модуля inspect
для будь-яких потреб самоаналізу.
Інтерфейс командного рядка¶
Модуль inspect
також надає базову можливість самоаналізу з командного рядка.
За замовчуванням приймає назву модуля та друкує джерело цього модуля. Натомість клас або функцію в модулі можна надрукувати, додавши двокрапку та кваліфіковане ім’я цільового об’єкта.
-
--details
¶
Надрукувати інформацію про вказаний об’єкт, а не вихідний код