importlib
— Реалізація import
¶
Нове в версії 3.1.
Вихідний код: Lib/importlib/__init__.py
вступ¶
The purpose of the importlib
package is three-fold.
One is to provide the
implementation of the import
statement (and thus, by extension, the
__import__()
function) in Python source code. This provides an
implementation of import
which is portable to any Python
interpreter. This also provides an implementation which is easier to
comprehend than one implemented in a programming language other than Python.
По-друге, компоненти для реалізації import
представлені в цьому пакунку, що полегшує користувачам створення власних користувацьких об’єктів (відомих загалом як importer) для участі в процесі імпорту.
Three, the package contains modules exposing additional functionality for managing aspects of Python packages:
importlib.metadata
presents access to metadata from third-party distributions.importlib.resources
provides routines for accessing non-code «resources» from Python packages.
Дивись також
- Оператор import
Посилання на мову для оператора
import
.- Специфікація пакетів
Оригінальна специфікація пакетів. Деяка семантика змінилася з моменту написання цього документа (наприклад, переспрямування на основі
None
уsys.modules
).- Функція
__import__()
Оператор
import
є синтаксичним цукром для цієї функції.- The initialization of the sys.path module search path
The initialization of
sys.path
.- PEP 235
Імпорт на платформи без урахування регістру
- PEP 263
Визначення кодувань вихідного коду Python
- PEP 302
Нові гачки імпорту
- PEP 328
Імпорт: багаторядковий і абсолютний/відносний
- PEP 366
Явний відносний імпорт головного модуля
- PEP 420
Неявні пакети простору імен
- PEP 451
Тип ModuleSpec для системи імпорту
- PEP 488
Видалення файлів PYO
- PEP 489
Багатофазна ініціалізація модуля розширення
- PEP 552
Детерміновані фото
- PEP 3120
Використання UTF-8 як вихідного кодування за умовчанням
- PEP 3147
Каталоги репозиторіїв PYC
Функції¶
- importlib.__import__(name, globals=None, locals=None, fromlist=(), level=0)¶
Реалізація вбудованої функції
__import__()
.Примітка
Програмне імпортування модулів має використовувати
import_module()
замість цієї функції.
- importlib.import_module(name, package=None)¶
Імпортувати модуль. Аргумент name визначає, який модуль імпортувати в абсолютних чи відносних значеннях (наприклад,
pkg.mod
або..mod
). Якщо ім’я вказано у відносних термінах, тоді в аргументі package має бути встановлено ім’я пакета, який має діяти як прив’язка для визначення імені пакета (наприклад,import_module('..mod', 'pkg' .subpkg')
імпортуєpkg.mod
).Функція
import_module()
діє як спрощена оболонка навколоimportlib.__import__()
. Це означає, що вся семантика функції походить відimportlib.__import__()
. Найважливіша відмінність між цими двома функціями полягає в тому, щоimport_module()
повертає вказаний пакунок або модуль (наприклад,pkg.mod
), а__import__()
повертає пакунок або модуль верхнього рівня (напр.пакет
).Якщо ви динамічно імпортуєте модуль, який було створено після того, як інтерпретатор почав виконання (наприклад, створив вихідний файл Python), вам може знадобитися викликати
invalidate_caches()
, щоб система імпорту помітила новий модуль.Змінено в версії 3.3: Батьківські пакети імпортуються автоматично.
- importlib.find_loader(name, path=None)¶
Find the loader for a module, optionally within the specified path. If the module is in
sys.modules
, thensys.modules[name].__loader__
is returned (unless the loader would beNone
or is not set, in which caseValueError
is raised). Otherwise a search usingsys.meta_path
is done.None
is returned if no loader is found.A dotted name does not have its parents implicitly imported as that requires loading them and that may not be desired. To properly import a submodule you will need to import all parent packages of the submodule and use the correct argument to path.
Нове в версії 3.3.
Змінено в версії 3.4: If
__loader__
is not set, raiseValueError
, just like when the attribute is set toNone
.Застаріло починаючи з версії 3.4: Use
importlib.util.find_spec()
instead.
- importlib.invalidate_caches()¶
Визнати недійсними внутрішні кеші засобів пошуку, які зберігаються в
sys.meta_path
. Якщо засіб пошуку реалізуєinvalidate_caches()
, тоді він буде викликаний для виконання недійсності. Цю функцію слід викликати, якщо будь-які модулі створюються/встановлюються під час роботи вашої програми, щоб гарантувати, що всі шукачі помітять існування нового модуля.Нове в версії 3.3.
Змінено в версії 3.10: Namespace packages created/installed in a different
sys.path
location after the same namespace was already imported are noticed.
- importlib.reload(module)¶
Перезавантажте раніше імпортований модуль. Аргумент має бути об’єктом модуля, тому він має бути успішно імпортований раніше. Це корисно, якщо ви відредагували вихідний файл модуля за допомогою зовнішнього редактора і хочете випробувати нову версію, не виходячи з інтерпретатора Python. Поверненим значенням є об’єкт модуля (який може бути іншим, якщо повторне імпортування спричиняє розміщення іншого об’єкта в
sys.modules
).Коли
reload()
виконується:Код модуля Python перекомпілюється, а код рівня модуля повторно виконується, визначаючи новий набір об’єктів, які прив’язуються до імен у словнику модуля шляхом повторного використання loader, який початково завантажив модуль. Функція
init
модулів розширення не викликається вдруге.Як і у випадку з усіма іншими об’єктами в Python, старі об’єкти відновлюються лише після того, як їх кількість посилань зменшується до нуля.
Імена в просторі імен модуля оновлюються, щоб вказувати на будь-які нові або змінені об’єкти.
Інші посилання на старі об’єкти (наприклад, імена, зовнішні по відношенню до модуля) не повертаються до нових об’єктів і повинні бути оновлені в кожному просторі імен, де вони зустрічаються, якщо це потрібно.
Існує ряд інших застережень:
Коли модуль перезавантажується, його словник (що містить глобальні змінні модуля) зберігається. Перевизначення імен замінить старі визначення, тому це, як правило, не проблема. Якщо нова версія модуля не визначає назву, яка була визначена старою версією, старе визначення залишається. Цю функцію можна використовувати на користь модуля, якщо він підтримує глобальну таблицю або кеш об’єктів — за допомогою оператора
try
він може перевірити наявність таблиці та за бажанням пропустити її ініціалізацію:try: cache except NameError: cache = {}
Зазвичай не дуже корисно перезавантажувати вбудовані або динамічно завантажувані модулі. Перезавантажувати
sys
,__main__
,builtins
та інші ключові модулі не рекомендується. У багатьох випадках модулі розширення не призначені для ініціалізації більше одного разу, і можуть виникати будь-які збої під час перезавантаження.Якщо модуль імпортує об’єкти з іншого модуля за допомогою
from
…import
…, викликreload()
для іншого модуля не перевизначає об’єкти, імпортовані з нього — один із способів обійти це — повторно виконати операторfrom
, інший — використати замість ньогоimport
і кваліфіковані імена (module.name).Якщо модуль створює екземпляри класу, перезавантаження модуля, який визначає клас, не впливає на визначення методів екземплярів — вони продовжують використовувати старе визначення класу. Те саме стосується похідних класів.
Нове в версії 3.4.
Змінено в версії 3.7:
ModuleNotFoundError
виникає, коли модуль, який перезавантажується, не маєModuleSpec
.
importlib.abc
– Абстрактні базові класи, пов’язані з імпортом¶
Вихідний код: Lib/importlib/abc.py
Модуль importlib.abc
містить усі основні абстрактні базові класи, які використовуються import
. Деякі підкласи основних абстрактних базових класів також надаються для допомоги в реалізації основних ABC.
Ієрархія ABC:
object
+-- Finder (deprecated)
+-- MetaPathFinder
+-- PathEntryFinder
+-- Loader
+-- ResourceLoader --------+
+-- InspectLoader |
+-- ExecutionLoader --+
+-- FileLoader
+-- SourceLoader
- class importlib.abc.Finder¶
An abstract base class representing a finder.
Застаріло починаючи з версії 3.3: Use
MetaPathFinder
orPathEntryFinder
instead.- abstractmethod find_module(fullname, path=None)¶
An abstract method for finding a loader for the specified module. Originally specified in PEP 302, this method was meant for use in
sys.meta_path
and in the path-based import subsystem.Змінено в версії 3.4: Returns
None
when called instead of raisingNotImplementedError
.Застаріло починаючи з версії 3.10: Implement
MetaPathFinder.find_spec()
orPathEntryFinder.find_spec()
instead.
- class importlib.abc.MetaPathFinder¶
Абстрактний базовий клас, що представляє meta path finder.
Нове в версії 3.3.
Змінено в версії 3.10: No longer a subclass of
Finder
.- find_spec(fullname, path, target=None)¶
Абстрактний метод для пошуку spec для вказаного модуля. Якщо це імпорт верхнього рівня, path матиме значення
None
. В іншому випадку це буде пошук підпакета або модуля, і path буде значенням__path__
з батьківського пакета. Якщо специфікацію неможливо знайти, повертаєтьсяNone
. Коли передано,target
є об’єктом модуля, який шукач може використовувати, щоб зробити більш освічене припущення про те, яку специфікацію потрібно повернути.importlib.util.spec_from_loader()
може бути корисним для реалізації конкретнихMetaPathFinders
.Нове в версії 3.4.
- find_module(fullname, path)¶
A legacy method for finding a loader for the specified module. If this is a top-level import, path will be
None
. Otherwise, this is a search for a subpackage or module and path will be the value of__path__
from the parent package. If a loader cannot be found,None
is returned.If
find_spec()
is defined, backwards-compatible functionality is provided.Змінено в версії 3.4: Returns
None
when called instead of raisingNotImplementedError
. Can usefind_spec()
to provide functionality.Застаріло починаючи з версії 3.4: Use
find_spec()
instead.
- invalidate_caches()¶
Додатковий метод, який під час виклику має зробити недійсним будь-який внутрішній кеш, який використовує шукач. Використовується
importlib.invalidate_caches()
під час визнання недійсними кешів усіх засобів пошуку наsys.meta_path
.Змінено в версії 3.4: Returns
None
when called instead ofNotImplemented
.
- class importlib.abc.PathEntryFinder¶
Абстрактний базовий клас, що представляє path entry finder. Хоча він має певну схожість із
MetaPathFinder
,PathEntryFinder
призначений для використання лише в підсистемі імпорту на основі шляху, яку надаєimportlib.machinery.PathFinder
.Нове в версії 3.3.
Змінено в версії 3.10: No longer a subclass of
Finder
.- find_spec(fullname, target=None)¶
Абстрактний метод для пошуку spec для вказаного модуля. Шукач шукатиме модуль лише в межах path entry, якому він призначений. Якщо специфікацію неможливо знайти, повертається
None
. Коли передано,target
є об’єктом модуля, який шукач може використовувати, щоб зробити більш освічене припущення про те, яку специфікацію потрібно повернути.importlib.util.spec_from_loader()
може бути корисним для реалізації конкретнихPathEntryFinders
.Нове в версії 3.4.
- find_loader(fullname)¶
A legacy method for finding a loader for the specified module. Returns a 2-tuple of
(loader, portion)
whereportion
is a sequence of file system locations contributing to part of a namespace package. The loader may beNone
while specifyingportion
to signify the contribution of the file system locations to a namespace package. An empty list can be used forportion
to signify the loader is not part of a namespace package. Ifloader
isNone
andportion
is the empty list then no loader or location for a namespace package were found (i.e. failure to find anything for the module).If
find_spec()
is defined then backwards-compatible functionality is provided.Змінено в версії 3.4: Returns
(None, [])
instead of raisingNotImplementedError
. Usesfind_spec()
when available to provide functionality.Застаріло починаючи з версії 3.4: Use
find_spec()
instead.
- find_module(fullname)¶
A concrete implementation of
Finder.find_module()
which is equivalent toself.find_loader(fullname)[0]
.Застаріло починаючи з версії 3.4: Use
find_spec()
instead.
- invalidate_caches()¶
Додатковий метод, який під час виклику має зробити недійсним будь-який внутрішній кеш, який використовує шукач. Використовується
importlib.machinery.PathFinder.invalidate_caches()
під час визнання недійсними кешів усіх кешованих засобів пошуку.
- class importlib.abc.Loader¶
Абстрактний базовий клас для loader. Перегляньте PEP 302 для точного визначення завантажувача.
Loaders that wish to support resource reading should implement a
get_resource_reader()
method as specified byimportlib.resources.abc.ResourceReader
.Змінено в версії 3.7: Introduced the optional
get_resource_reader()
method.- create_module(spec)¶
Метод, який повертає об’єкт модуля для використання під час імпорту модуля. Цей метод може повертати
None
, вказуючи, що семантика створення модуля за замовчуванням має мати місце.Нове в версії 3.4.
Змінено в версії 3.6: This method is no longer optional when
exec_module()
is defined.
- exec_module(module)¶
An abstract method that executes the module in its own namespace when a module is imported or reloaded. The module should already be initialized when
exec_module()
is called. When this method exists,create_module()
must be defined.Нове в версії 3.4.
Змінено в версії 3.6:
create_module()
must also be defined.
- load_module(fullname)¶
A legacy method for loading a module. If the module cannot be loaded,
ImportError
is raised, otherwise the loaded module is returned.If the requested module already exists in
sys.modules
, that module should be used and reloaded. Otherwise the loader should create a new module and insert it intosys.modules
before any loading begins, to prevent recursion from the import. If the loader inserted a module and the load fails, it must be removed by the loader fromsys.modules
; modules already insys.modules
before the loader began execution should be left alone (seeimportlib.util.module_for_loader()
).The loader should set several attributes on the module (note that some of these attributes can change when a module is reloaded):
__name__
The module’s fully qualified name. It is
'__main__'
for an executed module.
__cached__
The filename of a compiled version of the module’s code. It is not set on all modules (e.g. built-in modules).
__path__
The list of locations where the package’s submodules will be found. Most of the time this is a single directory. The import system passes this attribute to
__import__()
and to finders in the same way assys.path
but just for the package. It is not set on non-package modules so it can be used as an indicator that the module is a package.
__package__
The fully qualified name of the package the module is in (or the empty string for a top-level module). If the module is a package then this is the same as
__name__
.
__loader__
The loader used to load the module.
Коли
exec_module()
доступний, тоді надається функція зворотної сумісності.Змінено в версії 3.4: Raise
ImportError
when called instead ofNotImplementedError
. Functionality provided whenexec_module()
is available.Застаріло починаючи з версії 3.4: The recommended API for loading a module is
exec_module()
(andcreate_module()
). Loaders should implement it instead ofload_module()
. The import machinery takes care of all the other responsibilities ofload_module()
whenexec_module()
is implemented.
- module_repr(module)¶
A legacy method which when implemented calculates and returns the given module’s representation, as a string. The module type’s default
__repr__()
will use the result of this method as appropriate.Нове в версії 3.3.
Змінено в версії 3.4: Made optional instead of an abstractmethod.
Застаріло починаючи з версії 3.4: The import machinery now takes care of this automatically.
- class importlib.abc.ResourceLoader¶
Абстрактний базовий клас для loader, який реалізує необов’язковий протокол PEP 302 для завантаження довільних ресурсів із внутрішнього сховища.
Застаріло починаючи з версії 3.7: This ABC is deprecated in favour of supporting resource loading through
importlib.resources.abc.ResourceReader
.- abstractmethod get_data(path)¶
Абстрактний метод для повернення байтів для даних, розташованих за шляхом. Завантажувачі, які мають серверну систему зберігання, подібну до файлів, яка дозволяє зберігати довільні дані, можуть реалізувати цей абстрактний метод, щоб надати прямий доступ до збережених даних.
OSError
виникає, якщо шлях не може бути знайдений. Очікується, що шлях буде створено за допомогою атрибута__file__
модуля або елемента з__path__
пакета.Змінено в версії 3.4: Викликає
OSError
замістьNotImplementedError
.
- class importlib.abc.InspectLoader¶
Абстрактний базовий клас для loader, який реалізує додатковий протокол PEP 302 для завантажувачів, які перевіряють модулі.
- get_code(fullname)¶
Повертає об’єкт коду для модуля або
None
, якщо модуль не має об’єкта коду (як, наприклад, у випадку вбудованого модуля). ВикликатиImportError
, якщо завантажувач не може знайти запитуваний модуль.Примітка
Хоча метод має реалізацію за замовчуванням, пропонується замінити його, якщо це можливо для продуктивності.
Змінено в версії 3.4: Більше не абстрактне, а конкретна реалізація.
- abstractmethod get_source(fullname)¶
Абстрактний метод для повернення вихідного коду модуля. Він повертається як текстовий рядок з використанням universal newlines, переводячи всі розпізнані роздільники рядків у символи
'\n'
. ПовертаєNone
, якщо джерело недоступне (наприклад, вбудований модуль). ВикликаєImportError
, якщо завантажувач не може знайти вказаний модуль.Змінено в версії 3.4: Викликає
ImportError
замістьNotImplementedError
.
- is_package(fullname)¶
Додатковий метод для повернення істинного значення, якщо модуль є пакетом, і хибного значення в іншому випадку.
ImportError
виникає, якщо loader не може знайти модуль.Змінено в версії 3.4: Викликає
ImportError
замістьNotImplementedError
.
- static source_to_code(data, path='<string>')¶
Створіть об’єкт коду з джерела Python.
Аргументом data може бути те, що підтримує функція
compile()
(тобто рядок або байти). Аргумент path має бути «шляхом», звідки походить вихідний код, що може бути абстрактним поняттям (наприклад, розташуванням у файлі zip).З наступним об’єктом коду можна виконати його в модулі, запустивши
exec(code, module.__dict__)
.Нове в версії 3.4.
Змінено в версії 3.5: Зробив метод статичним.
- exec_module(module)¶
Реалізація
Loader.exec_module()
.Нове в версії 3.4.
- load_module(fullname)¶
Реалізація
Loader.load_module()
.Застаріло починаючи з версії 3.4: замість цього використовуйте
exec_module()
.
- class importlib.abc.ExecutionLoader¶
Абстрактний базовий клас, успадкований від
InspectLoader
, який, реалізований, допомагає модулю виконуватися як сценарій. ABC представляє необов’язковий протокол PEP 302.- abstractmethod get_filename(fullname)¶
Абстрактний метод, який повертає значення
__file__
для зазначеного модуля. Якщо шлях недоступний, виникаєImportError
.Якщо вихідний код доступний, тоді метод має повертати шлях до вихідного файлу, незалежно від того, чи використовувався байт-код для завантаження модуля.
Змінено в версії 3.4: Викликає
ImportError
замістьNotImplementedError
.
- class importlib.abc.FileLoader(fullname, path)¶
Абстрактний базовий клас, який успадковує
ResourceLoader
іExecutionLoader
, надаючи конкретні реалізаціїResourceLoader.get_data()
іExecutionLoader.get_filename()
.Аргумент повне ім’я — це повністю визначене ім’я модуля, який має обробляти завантажувач. Аргумент path — це шлях до файлу модуля.
Нове в версії 3.3.
- name¶
Назва модуля, який може обробляти завантажувач.
- path¶
Шлях до файлу модуля.
- load_module(fullname)¶
Викликає
load_module()
супер.Застаріло починаючи з версії 3.4: Натомість використовуйте
Loader.exec_module()
.
- abstractmethod get_data(path)¶
Читає шлях як двійковий файл і повертає байти з нього.
- class importlib.abc.SourceLoader¶
Абстрактний базовий клас для реалізації вихідного (і необов’язково байт-коду) завантаження файлу. Клас успадковує як
ResourceLoader
, так іExecutionLoader
, що вимагає реалізації:ExecutionLoader.get_filename()
Має повертати лише шлях до вихідного файлу; завантаження без джерел не підтримується.
Абстрактні методи, визначені цим класом, призначені для додавання додаткової підтримки файлу байт-коду. Нереалізація цих додаткових методів (або виклик їх
NotImplementedError
) змушує завантажувач працювати лише з вихідним кодом. Реалізація методів дозволяє завантажувачу працювати з вихідними та файлами байт-коду; він не допускає безджерельного завантаження, де надається лише байт-код. Файли байт-коду є оптимізацією для прискорення завантаження шляхом видалення кроку синтаксичного аналізу компілятора Python, тому API, специфічний для байт-коду, не розкривається.- path_stats(path)¶
Додатковий абстрактний метод, який повертає
dict
, що містить метадані про вказаний шлях. Підтримувані ключі словника:'mtime'
(обов’язковий): ціле число або число з плаваючою комою, що представляє час модифікації вихідного коду;'size'
(необов’язковий): розмір у байтах вихідного коду.
Будь-які інші ключі в словнику ігноруються, щоб дозволити майбутні розширення. Якщо шлях не можна обробити, виникає
OSError
.Нове в версії 3.3.
Змінено в версії 3.4: Викликати
OSError
замістьNotImplementedError
.
- path_mtime(path)¶
Додатковий абстрактний метод, який повертає час модифікації для вказаного шляху.
Застаріло починаючи з версії 3.3: Цей метод застарів на користь
path_stats()
. Вам не потрібно його впроваджувати, але він все ще доступний для цілей сумісності. ВикликатиOSError
, якщо шлях неможливо обробити.Змінено в версії 3.4: Викликати
OSError
замістьNotImplementedError
.
- set_data(path, data)¶
Додатковий абстрактний метод, який записує вказані байти в шлях до файлу. Будь-які проміжні каталоги, яких не існує, створюються автоматично.
When writing to the path fails because the path is read-only (
errno.EACCES
/PermissionError
), do not propagate the exception.Змінено в версії 3.4: Більше не викликає
NotImplementedError
під час виклику.
- get_code(fullname)¶
Конкретна реалізація
InspectLoader.get_code()
.
- exec_module(module)¶
Конкретна реалізація
Loader.exec_module()
.Нове в версії 3.4.
- load_module(fullname)¶
Конкретна реалізація
Loader.load_module()
.Застаріло починаючи з версії 3.4: Замість цього використовуйте
exec_module()
.
- get_source(fullname)¶
Конкретна реалізація
InspectLoader.get_source()
.
- is_package(fullname)¶
Конкретна реалізація
InspectLoader.is_package()
. Модуль вважається пакетом, якщо його шлях до файлу (як наданоExecutionLoader.get_filename()
) є файлом з назвою__init__
, коли розширення файлу видалено і сама назва модуля не закінчується на__init__
.
importlib.machinery
– Імпортери та перехоплювачі шляху¶
Вихідний код: Lib/importlib/machinery.py
Цей модуль містить різноманітні об’єкти, які допомагають import
знаходити та завантажувати модулі.
- importlib.machinery.SOURCE_SUFFIXES¶
Список рядків, що представляють розпізнані суфікси файлів для вихідних модулів.
Нове в версії 3.3.
- importlib.machinery.DEBUG_BYTECODE_SUFFIXES¶
Список рядків, що представляють суфікси файлів для неоптимізованих модулів байт-коду.
Нове в версії 3.3.
Застаріло починаючи з версії 3.5: Натомість використовуйте
BYTECODE_SUFFIXES
.
- importlib.machinery.OPTIMIZED_BYTECODE_SUFFIXES¶
Список рядків, що представляють суфікси файлів для оптимізованих модулів байт-коду.
Нове в версії 3.3.
Застаріло починаючи з версії 3.5: Натомість використовуйте
BYTECODE_SUFFIXES
.
- importlib.machinery.BYTECODE_SUFFIXES¶
Список рядків, що представляють розпізнані суфікси файлів для модулів байт-коду (включно з початковою крапкою).
Нове в версії 3.3.
Змінено в версії 3.5: Значення більше не залежить від
__debug__
.
- importlib.machinery.EXTENSION_SUFFIXES¶
Список рядків, що представляють розпізнані суфікси файлів для модулів розширення.
Нове в версії 3.3.
- importlib.machinery.all_suffixes()¶
Повертає комбінований список рядків, що представляють усі суфікси файлів для модулів, розпізнаних стандартним механізмом імпорту. Це допоміжний засіб для коду, якому просто потрібно знати, чи шлях до файлової системи потенційно посилається на модуль, не потребуючи жодних деталей щодо типу модуля (наприклад,
inspect.getmodulename()
).Нове в версії 3.3.
- class importlib.machinery.BuiltinImporter¶
importer для вбудованих модулів. Усі відомі вбудовані модулі перераховані в
sys.builtin_module_names
. Цей клас реалізує ABCimportlib.abc.MetaPathFinder
іimportlib.abc.InspectLoader
.У цьому класі визначені лише методи класу, щоб полегшити потребу в створенні екземплярів.
Змінено в версії 3.5: Як частина PEP 489, вбудований імпортер тепер реалізує
Loader.create_module()
іLoader.exec_module()
- class importlib.machinery.FrozenImporter¶
importer для заморожених модулів. Цей клас реалізує ABC
importlib.abc.MetaPathFinder
іimportlib.abc.InspectLoader
.У цьому класі визначені лише методи класу, щоб полегшити потребу в створенні екземплярів.
Змінено в версії 3.4: Отримано методи
create_module()
іexec_module()
.
- class importlib.machinery.WindowsRegistryFinder¶
Finder для модулів, оголошених у реєстрі Windows. Цей клас реалізує
importlib.abc.MetaPathFinder
ABC.У цьому класі визначені лише методи класу, щоб полегшити потребу в створенні екземплярів.
Нове в версії 3.3.
Застаріло починаючи з версії 3.6: Натомість використовуйте конфігурацію
site
. Майбутні версії Python можуть не вмикати цей засіб пошуку за замовчуванням.
- class importlib.machinery.PathFinder¶
A Finder для атрибутів
sys.path
і пакета__path__
. Цей клас реалізуєimportlib.abc.MetaPathFinder
ABC.У цьому класі визначені лише методи класу, щоб полегшити потребу в створенні екземплярів.
- classmethod find_spec(fullname, path=None, target=None)¶
Метод класу, який намагається знайти spec для модуля, указаного повним ім’ям у
sys.path
або, якщо визначено, у path. Для кожного запису шляху, який шукається, перевіряєтьсяsys.path_importer_cache
. Якщо знайдено нефальшивий об’єкт, він використовується як path entry finder для пошуку модуля, який шукається. Якщо вsys.path_importer_cache
не знайдено жодного запису, тодіsys.path_hooks
шукає засіб пошуку для запису шляху та, якщо знайдено, зберігається вsys.path_importer_cache
із запитанням про модуль. Якщо жоден шукач не знайдено, тодіNone
зберігається в кеші та повертається.Нове в версії 3.4.
Змінено в версії 3.5: Якщо поточний робочий каталог, представлений порожнім рядком, більше не дійсний, тоді повертається
None
, але жодне значення не кешується вsys.path_importer_cache
.
- classmethod find_module(fullname, path=None)¶
A legacy wrapper around
find_spec()
.Застаріло починаючи з версії 3.4: Use
find_spec()
instead.
- classmethod invalidate_caches()¶
Викликає
importlib.abc.PathEntryFinder.invalidate_caches()
для всіх засобів пошуку, збережених уsys.path_importer_cache
, які визначають метод. Інакше записи вsys.path_importer_cache
, для яких встановлено значенняNone
, видаляються.Змінено в версії 3.7: Записи
None
уsys.path_importer_cache
видаляються.
Змінено в версії 3.4: Викликає об’єкти в
sys.path_hooks
з поточним робочим каталогом для''
(тобто порожній рядок).
- class importlib.machinery.FileFinder(path, *loader_details)¶
Конкретна реалізація
importlib.abc.PathEntryFinder
, яка кешує результати з файлової системи.Аргумент шлях — це каталог, пошук якого відповідає за пошук.
Аргумент loader_details — це змінна кількість кортежів із 2 елементів, кожен із яких містить завантажувач і послідовність суфіксів файлів, які розпізнає завантажувач. Очікується, що завантажувачі будуть викликаними, які приймають два аргументи імені модуля та шляху до знайденого файлу.
Засіб пошуку кешуватиме вміст каталогу за потреби, виконуючи stat виклики для кожного пошуку модуля, щоб переконатися, що кеш не застарів. Оскільки нестабільність кешу залежить від деталізації інформації про стан операційної системи файлової системи, існує потенційна конкуренція щодо пошуку модуля, створення нового файлу, а потім пошуку модуля, який представляє новий файл. Якщо операції відбуваються досить швидко, щоб відповідати деталізації викликів stat, пошук модулів не вдасться. Щоб цього не сталося, під час динамічного створення модуля обов’язково викликайте
importlib.invalidate_caches()
.Нове в версії 3.3.
- path¶
Шлях, за яким шукач шукатиме.
- find_spec(fullname, target=None)¶
Спробуйте знайти специфікацію для обробки повного імені в
path
.Нове в версії 3.4.
- find_loader(fullname)¶
Attempt to find the loader to handle fullname within
path
.Застаріло починаючи з версії 3.10: Use
find_spec()
instead.
- invalidate_caches()¶
Очистіть внутрішній кеш.
- classmethod path_hook(*loader_details)¶
A class method which returns a closure for use on
sys.path_hooks
. An instance ofFileFinder
is returned by the closure using the path argument given to the closure directly and loader_details indirectly.Якщо аргумент закриття не є існуючим каталогом, виникає
ImportError
.
- class importlib.machinery.SourceFileLoader(fullname, path)¶
Конкретна реалізація
importlib.abc.SourceLoader
шляхом створення підкласуimportlib.abc.FileLoader
і надання деяких конкретних реалізацій інших методів.Нове в версії 3.3.
- name¶
Назва модуля, який оброблятиме цей завантажувач.
- path¶
Шлях до вихідного файлу.
- path_stats(path)¶
Конкретна реалізація
importlib.abc.SourceLoader.path_stats()
.
- set_data(path, data)¶
Конкретна реалізація
importlib.abc.SourceLoader.set_data()
.
- load_module(name=None)¶
Конкретна реалізація
importlib.abc.Loader.load_module()
, де вказувати назву модуля для завантаження необов’язково.Застаріло починаючи з версії 3.6: Замість цього використовуйте
importlib.abc.Loader.exec_module()
.
- class importlib.machinery.SourcelessFileLoader(fullname, path)¶
Конкретна реалізація
importlib.abc.FileLoader
, яка може імпортувати файли байт-коду (тобто файлів вихідного коду не існує).Зауважте, що пряме використання файлів байт-коду (а отже, не файлів вихідного коду) перешкоджає використанню ваших модулів усіма реалізаціями Python або новими версіями Python, які змінюють формат байт-коду.
Нове в версії 3.3.
- name¶
Назва модуля, який оброблятиме завантажувач.
- path¶
Шлях до файлу байт-коду.
- get_source(fullname)¶
Повертає
None
, оскільки файли байт-коду не мають джерела, коли використовується цей завантажувач.
- load_module(name=None)¶
Конкретна реалізація
importlib.abc.Loader.load_module()
, де вказувати назву модуля для завантаження необов’язково.Застаріло починаючи з версії 3.6: Замість цього використовуйте
importlib.abc.Loader.exec_module()
.
- class importlib.machinery.ExtensionFileLoader(fullname, path)¶
Конкретна реалізація
importlib.abc.ExecutionLoader
для модулів розширення.Аргумент fullname вказує назву модуля, який має підтримувати завантажувач. Аргумент path — це шлях до файлу модуля розширення.
Нове в версії 3.3.
- name¶
Назва модуля, який підтримує завантажувач.
- path¶
Шлях до модуля розширення.
- create_module(spec)¶
Створює об’єкт модуля з заданої специфікації відповідно до PEP 489.
Нове в версії 3.5.
- is_package(fullname)¶
Повертає
True
, якщо шлях до файлу вказує на модуль__init__
пакета на основіEXTENSION_SUFFIXES
.
- get_code(fullname)¶
Повертає
None
, оскільки модулі розширення не мають об’єкта коду.
- get_source(fullname)¶
Повертає
None
, оскільки модулі розширення не мають вихідного коду.
- class importlib.machinery.NamespaceLoader(name, path, path_finder)¶
A concrete implementation of
importlib.abc.InspectLoader
for namespace packages. This is an alias for a private class and is only made public for introspecting the__loader__
attribute on namespace packages:>>> from importlib.machinery import NamespaceLoader >>> import my_namespace >>> isinstance(my_namespace.__loader__, NamespaceLoader) True >>> import importlib.abc >>> isinstance(my_namespace.__loader__, importlib.abc.Loader) True
Нове в версії 3.11.
- class importlib.machinery.ModuleSpec(name, loader, *, origin=None, loader_state=None, is_package=None)¶
A specification for a module’s import-system-related state. This is typically exposed as the module’s
__spec__
attribute. In the descriptions below, the names in parentheses give the corresponding attribute available directly on the module object, e.g.module.__spec__.origin == module.__file__
. Note, however, that while the values are usually equivalent, they can differ since there is no synchronization between the two objects. For example, it is possible to update the module’s__file__
at runtime and this will not be automatically reflected in the module’s__spec__.origin
, and vice versa.Нове в версії 3.4.
- name¶
(
__name__
)The module’s fully qualified name. The finder should always set this attribute to a non-empty string.
- loader¶
The loader used to load the module. The finder should always set this attribute.
- origin¶
(
__file__
)The location the loader should use to load the module. For example, for modules loaded from a .py file this is the filename. The finder should always set this attribute to a meaningful value for the loader to use. In the uncommon case that there is not one (like for namespace packages), it should be set to
None
.- submodule_search_locations¶
(
__path__
)The list of locations where the package’s submodules will be found. Most of the time this is a single directory. The finder should set this attribute to a list, even an empty one, to indicate to the import system that the module is a package. It should be set to
None
for non-package modules. It is set automatically later to a special object for namespace packages.- loader_state¶
The finder may set this attribute to an object containing additional, module-specific data to use when loading the module. Otherwise it should be set to
None
.- cached¶
The filename of a compiled version of the module’s code. The finder should always set this attribute but it may be
None
for modules that do not need compiled code stored.- parent¶
(Read-only) The fully qualified name of the package the module is in (or the empty string for a top-level module). If the module is a package then this is the same as
name
.- has_location¶
importlib.util
– Код утиліти для імпортерів¶
Вихідний код: Lib/importlib/util.py
Цей модуль містить різні об’єкти, які допомагають у створенні importer.
- importlib.util.MAGIC_NUMBER¶
Байти, які представляють номер версії байт-коду. Якщо вам потрібна допомога із завантаженням/записом байт-коду, скористайтеся
importlib.abc.SourceLoader
.Нове в версії 3.4.
- importlib.util.cache_from_source(path, debug_override=None, *, optimization=None)¶
Поверніть шлях PEP 3147/PEP 488 до скомпільованого файлу, пов’язаного з вихідним шляхом. Наприклад, якщо path є
/foo/bar/baz.py
, значення, що повертається, буде/foo/bar/__pycache__/baz.cpython-32.pyc
для Python 3.2. Рядокcpython-32
походить від поточного магічного тегу (див.get_tag()
; якщоsys.implementation.cache_tag
не визначено, тоді буде викликанаNotImplementedError
).Параметр optimization використовується для визначення рівня оптимізації файлу байт-коду. Порожній рядок не означає оптимізації, тому
/foo/bar/baz.py
з оптимізацією''
призведе до шляху байт-коду/foo/bar/__pycache__/baz. cpython-32.pyc
.None
спричиняє використання рівня оптимізації інтерпретатора. Використовується будь-яке інше представлення рядка значення, тому/foo/bar/baz.py
з оптимізацією2
призведе до шляху байт-коду/foo/bar/__pycache__/baz. cpython-32.opt-2.pyc
. Рядкове представлення оптимізації може бути лише буквено-цифровим, інакше виникаєValueError
.Параметр debug_override є застарілим і може використовуватися для заміни системного значення для
__debug__
. ЗначенняTrue
є еквівалентом налаштування optimization для порожнього рядка. ЗначенняFalse
те саме, що встановити optimization на1
. Якщо debug_override і оптимізація не мають значенняNone
, тоді виникаєTypeError
.Нове в версії 3.4.
Змінено в версії 3.5: Параметр optimization було додано, а параметр debug_override визнано застарілим.
Змінено в версії 3.6: Приймає path-like object.
- importlib.util.source_from_cache(path)¶
Враховуючи шлях до імені файлу PEP 3147, поверніть пов’язаний шлях до файлу вихідного коду. Наприклад, якщо шлях є
/foo/bar/__pycache__/baz.cpython-32.pyc
, повернутий шлях буде/foo/bar/baz.py
. path не обов’язково існує, однак якщо він не відповідає формату PEP 3147 або PEP 488, виникає помилкаValueError
. Якщоsys.implementation.cache_tag
не визначено, виникаєNotImplementedError
.Нове в версії 3.4.
Змінено в версії 3.6: Приймає path-like object.
- importlib.util.decode_source(source_bytes)¶
Декодуйте задані байти, що представляють вихідний код, і поверніть його як рядок із універсальними символами нового рядка (як вимагає
importlib.abc.InspectLoader.get_source()
).Нове в версії 3.4.
- importlib.util.resolve_name(name, package)¶
Розділіть відносну назву модуля на абсолютну.
Якщо ім’я не має початкових крапок, то ім’я просто повертається. Це дозволяє використовувати таке як
importlib.util.resolve_name('sys', __spec__.parent)
без виконання перевірки, щоб побачити, чи потрібен аргумент package.ImportError
is raised if name is a relative module name but package is a false value (e.g.None
or the empty string).ImportError
is also raised if a relative name would escape its containing package (e.g. requesting..bacon
from within thespam
package).Нове в версії 3.3.
Змінено в версії 3.9: Щоб покращити узгодженість із операторами імпорту, підніміть
ImportError
замістьValueError
для недійсних відносних спроб імпорту.
- importlib.util.find_spec(name, package=None)¶
Find the spec for a module, optionally relative to the specified package name. If the module is in
sys.modules
, thensys.modules[name].__spec__
is returned (unless the spec would beNone
or is not set, in which caseValueError
is raised). Otherwise a search usingsys.meta_path
is done.None
is returned if no spec is found.Якщо назва призначена для підмодуля (містить крапку), батьківський модуль імпортується автоматично.
name і package працюють так само, як і для
import_module()
.Нове в версії 3.4.
Змінено в версії 3.7: Викликає
ModuleNotFoundError
замістьAttributeError
, якщо package насправді не є пакетом (тобто не має атрибута__path__
).
- importlib.util.module_from_spec(spec)¶
Створіть новий модуль на основі spec і
spec.loader.create_module
.Якщо
spec.loader.create_module
не повертаєNone
, тоді будь-які раніше існуючі атрибути не будуть скинуті. Крім того, помилкаAttributeError
не буде викликана, якщо вона буде активована під час доступу до spec або встановлення атрибута в модулі.Цій функції краще використовувати
types.ModuleType
для створення нового модуля, оскільки spec використовується для встановлення якомога більшої кількості керованих імпортом атрибутів для модуля.Нове в версії 3.5.
- @importlib.util.module_for_loader¶
A decorator for
importlib.abc.Loader.load_module()
to handle selecting the proper module object to load with. The decorated method is expected to have a call signature taking two positional arguments (e.g.load_module(self, module)
) for which the second argument will be the module object to be used by the loader. Note that the decorator will not work on static methods because of the assumption of two arguments.The decorated method will take in the name of the module to be loaded as expected for a loader. If the module is not found in
sys.modules
then a new one is constructed. Regardless of where the module came from,__loader__
set to self and__package__
is set based on whatimportlib.abc.InspectLoader.is_package()
returns (if available). These attributes are set unconditionally to support reloading.If an exception is raised by the decorated method and a module was added to
sys.modules
, then the module will be removed to prevent a partially initialized module from being in left insys.modules
. If the module was already insys.modules
then it is left alone.Змінено в версії 3.3:
__loader__
and__package__
are automatically set (when possible).Змінено в версії 3.4: Set
__name__
,__loader__
__package__
unconditionally to support reloading.Застаріло починаючи з версії 3.4: The import machinery now directly performs all the functionality provided by this function.
- @importlib.util.set_loader¶
A decorator for
importlib.abc.Loader.load_module()
to set the__loader__
attribute on the returned module. If the attribute is already set the decorator does nothing. It is assumed that the first positional argument to the wrapped method (i.e.self
) is what__loader__
should be set to.Змінено в версії 3.4: Set
__loader__
if set toNone
, as if the attribute does not exist.Застаріло починаючи з версії 3.4: The import machinery takes care of this automatically.
- @importlib.util.set_package¶
A decorator for
importlib.abc.Loader.load_module()
to set the__package__
attribute on the returned module. If__package__
is set and has a value other thanNone
it will not be changed.Застаріло починаючи з версії 3.4: The import machinery takes care of this automatically.
- importlib.util.spec_from_loader(name, loader, *, origin=None, is_package=None)¶
Фабрична функція для створення екземпляра
ModuleSpec
на основі завантажувача. Параметри мають таке ж значення, як і для ModuleSpec. Функція використовує доступні API loader, такі якInspectLoader.is_package()
, щоб заповнити будь-яку відсутню інформацію в специфікації.Нове в версії 3.4.
- importlib.util.spec_from_file_location(name, location, *, loader=None, submodule_search_locations=None)¶
Фабрична функція для створення екземпляра
ModuleSpec
на основі шляху до файлу. Відсутню інформацію буде заповнено в специфікації за допомогою API завантажувача та через те, що модуль буде заснований на файлі.Нове в версії 3.4.
Змінено в версії 3.6: Приймає path-like object.
- importlib.util.source_hash(source_bytes)¶
Повертає хеш source_bytes як байти. Файл
.pyc
на основі хешу вставляєsource_hash()
вмісту відповідного вихідного файлу у свій заголовок.Нове в версії 3.7.
- class importlib.util.LazyLoader(loader)¶
Клас, який відкладає виконання завантажувача модуля, поки модуль не отримає доступ до атрибута.
This class only works with loaders that define
exec_module()
as control over what module type is used for the module is required. For those same reasons, the loader’screate_module()
method must returnNone
or a type for which its__class__
attribute can be mutated along with not using slots. Finally, modules which substitute the object placed intosys.modules
will not work as there is no way to properly replace the module references throughout the interpreter safely;ValueError
is raised if such a substitution is detected.Примітка
Для проектів, де час запуску є критичним, цей клас дозволяє потенційно мінімізувати вартість завантаження модуля, якщо він ніколи не використовується. Для проектів, де час запуску не є суттєвим, використання цього класу суворо не рекомендується через те, що повідомлення про помилки, створені під час завантаження, відкладаються та, таким чином, виникають поза контекстом.
Нове в версії 3.5.
Змінено в версії 3.6: Почався виклик
create_module()
, видаляючи попередження про сумісність дляimportlib.machinery.BuiltinImporter
іimportlib.machinery.ExtensionFileLoader
.- classmethod factory(loader)¶
A class method which returns a callable that creates a lazy loader. This is meant to be used in situations where the loader is passed by class instead of by instance.
suffixes = importlib.machinery.SOURCE_SUFFIXES loader = importlib.machinery.SourceFileLoader lazy_loader = importlib.util.LazyLoader.factory(loader) finder = importlib.machinery.FileFinder(path, (lazy_loader, suffixes))
Приклади¶
Програмний імпорт¶
Щоб програмно імпортувати модуль, використовуйте importlib.import_module()
.
import importlib
itertools = importlib.import_module('itertools')
Перевірка можливості імпорту модуля¶
Якщо вам потрібно з’ясувати, чи можна імпортувати модуль без фактичного імпортування, тоді вам слід скористатися importlib.util.find_spec()
.
Зауважте, що якщо name
є підмодулем (містить крапку), importlib.util.find_spec()
імпортує батьківський модуль.
import importlib.util
import sys
# For illustrative purposes.
name = 'itertools'
if name in sys.modules:
print(f"{name!r} already in sys.modules")
elif (spec := importlib.util.find_spec(name)) is not None:
# If you chose to perform the actual import ...
module = importlib.util.module_from_spec(spec)
sys.modules[name] = module
spec.loader.exec_module(module)
print(f"{name!r} has been imported")
else:
print(f"can't find the {name!r} module")
Пряме імпортування вихідного файлу¶
To import a Python source file directly, use the following recipe:
import importlib.util
import sys
# For illustrative purposes.
import tokenize
file_path = tokenize.__file__
module_name = tokenize.__name__
spec = importlib.util.spec_from_file_location(module_name, file_path)
module = importlib.util.module_from_spec(spec)
sys.modules[module_name] = module
spec.loader.exec_module(module)
Реалізація відкладеного імпорту¶
У прикладі нижче показано, як реалізувати відкладений імпорт:
>>> import importlib.util
>>> import sys
>>> def lazy_import(name):
... spec = importlib.util.find_spec(name)
... loader = importlib.util.LazyLoader(spec.loader)
... spec.loader = loader
... module = importlib.util.module_from_spec(spec)
... sys.modules[name] = module
... loader.exec_module(module)
... return module
...
>>> lazy_typing = lazy_import("typing")
>>> #lazy_typing is a real module object,
>>> #but it is not loaded in memory yet.
>>> lazy_typing.TYPE_CHECKING
False
Налаштування імпортера¶
For deep customizations of import, you typically want to implement an
importer. This means managing both the finder and loader
side of things. For finders there are two flavours to choose from depending on
your needs: a meta path finder or a path entry finder. The
former is what you would put on sys.meta_path
while the latter is what
you create using a path entry hook on sys.path_hooks
which works
with sys.path
entries to potentially create a finder. This example will
show you how to register your own importers so that import will use them (for
creating an importer for yourself, read the documentation for the appropriate
classes defined within this package):
import importlib.machinery
import sys
# For illustrative purposes only.
SpamMetaPathFinder = importlib.machinery.PathFinder
SpamPathEntryFinder = importlib.machinery.FileFinder
loader_details = (importlib.machinery.SourceFileLoader,
importlib.machinery.SOURCE_SUFFIXES)
# Setting up a meta path finder.
# Make sure to put the finder in the proper location in the list in terms of
# priority.
sys.meta_path.append(SpamMetaPathFinder)
# Setting up a path entry finder.
# Make sure to put the path hook in the proper location in the list in terms
# of priority.
sys.path_hooks.append(SpamPathEntryFinder.path_hook(loader_details))
Наближення importlib.import_module()
¶
Import itself is implemented in Python code, making it possible to
expose most of the import machinery through importlib. The following
helps illustrate the various APIs that importlib exposes by providing an
approximate implementation of
importlib.import_module()
:
import importlib.util
import sys
def import_module(name, package=None):
"""An approximate implementation of import."""
absolute_name = importlib.util.resolve_name(name, package)
try:
return sys.modules[absolute_name]
except KeyError:
pass
path = None
if '.' in absolute_name:
parent_name, _, child_name = absolute_name.rpartition('.')
parent_module = import_module(parent_name)
path = parent_module.__spec__.submodule_search_locations
for finder in sys.meta_path:
spec = finder.find_spec(absolute_name, path)
if spec is not None:
break
else:
msg = f'No module named {absolute_name!r}'
raise ModuleNotFoundError(msg, name=absolute_name)
module = importlib.util.module_from_spec(spec)
sys.modules[absolute_name] = module
spec.loader.exec_module(module)
if path is not None:
setattr(parent_module, child_name, module)
return module