importlib.resources
– Package resource reading, opening and access¶
Source code: Lib/importlib/resources/__init__.py
Added in version 3.7.
This module leverages Python’s import system to provide access to resources within packages.
«Resources» are file-like resources associated with a module or package in Python. The resources may be contained directly in a package, within a subdirectory contained in that package, or adjacent to modules outside a package. Resources may be text or binary. As a result, Python module sources (.py) of a package and compilation artifacts (pycache) are technically de-facto resources of that package. In practice, however, resources are primarily those non-Python artifacts exposed specifically by the package author.
Resources can be opened or read in either binary or text mode.
Los recursos son más o menos similares a los archivos dentro de los directorios, aunque es importante tener en cuenta que esto es solo una metáfora. Los recursos y paquetes no deben existir como archivos y directorios físicos en el sistema de archivos: por ejemplo, un paquete y sus recursos se pueden importar desde un archivo zip usando zipimport
.
Nota
Este módulo proporciona una funcionalidad similar a pkg_resources Acceso a los recursos básicos sin la sobrecarga de rendimiento de ese paquete. Esto facilita la lectura de los recursos incluidos en los paquetes, con una semántica más estable y consistente.
El soporte independiente de este módulo proporciona más información sobre el uso de importlib.resources y migración de pkg_resources a importlib.resources.
Los loaders
que deseen soportar la lectura de recursos deben implementar un método get_resource_reader(fullname)
según lo especificado por importlib.resources.abc.ResourceReader
.
- class importlib.resources.Anchor¶
Represents an anchor for resources, either a
module object
or a module name as a string. Defined asUnion[str, ModuleType]
.
- importlib.resources.files(anchor: Anchor | None = None)¶
Returns a
Traversable
object representing the resource container (think directory) and its resources (think files). A Traversable may contain other containers (think subdirectories).anchor is an optional
Anchor
. If the anchor is a package, resources are resolved from that package. If a module, resources are resolved adjacent to that module (in the same package or the package root). If the anchor is omitted, the caller’s module is used.Added in version 3.9.
Distinto en la versión 3.12: package parameter was renamed to anchor. anchor can now be a non-package module and if omitted will default to the caller’s module. package is still accepted for compatibility but will raise a
DeprecationWarning
. Consider passing the anchor positionally or usingimportlib_resources >= 5.10
for a compatible interface on older Pythons.
- importlib.resources.as_file(traversable)¶
Given a
Traversable
object representing a file or directory, typically fromimportlib.resources.files()
, return a context manager for use in awith
statement. The context manager provides apathlib.Path
object.Exiting the context manager cleans up any temporary file or directory created when the resource was extracted from e.g. a zip file.
Use
as_file
when the Traversable methods (read_text
, etc) are insufficient and an actual file or directory on the file system is required.Added in version 3.9.
Distinto en la versión 3.12: Added support for traversable representing a directory.
Funciones en desuso¶
Todavía está disponible un conjunto de funciones más antiguo y en desuso, pero está programado para eliminarse en una versión futura de Python. El principal inconveniente de estas funciones es que no admiten directorios: asumen que todos los recursos están ubicados directamente dentro de un paquete.
- importlib.resources.Package¶
Cada vez que una función acepta un argumento
Package
, puede pasar unmodule object
o un nombre de módulo como una cadena. Solo puede pasar objetos de módulo cuyo__spec__.submodule_search_locations
no seaNone
.El tipo
Package
se define comoUnion[str, ModuleType]
.Obsoleto desde la versión 3.12.
- importlib.resources.Resource¶
Para los argumentos recurso de las siguientes funciones, puede pasar el nombre de un recurso como una cadena o
path-like object
.El tipo
Resource
se define comoUnion[str, os.PathLike]
.
- importlib.resources.open_binary(package, resource)¶
Abierto para lectura binaria de recurso dentro de paquete.
package es un nombre o un objeto de módulo que cumple con los requisitos de
Package
. resource es el nombre del recurso para abrir dentro de package; puede que no contenga separadores de ruta y que no tenga subrecursos (es decir, no puede ser un directorio). Esta función retorna una instanciatyping.BinaryIO
, un flujo de E/S binario abierto para lectura.Obsoleto desde la versión 3.11: Las llamadas a esta función se pueden reemplazar por:
files(package).joinpath(resource).open('rb')
- importlib.resources.open_text(package, resource, encoding='utf-8', errors='strict')¶
Abierto para texto que lea resource dentro de package. De forma predeterminada, el recurso se abre para lectura como UTF-8.
package es un nombre o un objeto de módulo que cumple con los requisitos de
Package
. resource es el nombre del recurso para abrir dentro de package; puede que no contenga separadores de ruta y que no tenga subrecursos (es decir, no puede ser un directorio). encoding y errors tienen el mismo significado que conopen()
incorporado.Esta función retorna una instancia
typing.TextIO
, un flujo de E/S de texto abierto para lectura.Obsoleto desde la versión 3.11: Las llamadas a esta función se pueden reemplazar por:
files(package).joinpath(resource).open('r', encoding=encoding)
- importlib.resources.read_binary(package, resource)¶
Lee y retorna el contenido de resource dentro de package como
bytes
.package es un nombre o un objeto de módulo que cumple con los requisitos de
Package
. resource es el nombre del recurso para abrir dentro de package; puede que no contenga separadores de ruta y que no tenga subrecursos (es decir, no puede ser un directorio). Esta función retorna el contenido del recurso comobytes
.Obsoleto desde la versión 3.11: Las llamadas a esta función se pueden reemplazar por:
files(package).joinpath(resource).read_bytes()
- importlib.resources.read_text(package, resource, encoding='utf-8', errors='strict')¶
Lee y retorna el contenido de resource dentro de package como
str
. De forma predeterminada, los contenidos se leen como UTF-8 estricto.package es un nombre o un objeto de módulo que cumple con los requisitos de
Package
. resource es el nombre del recurso para abrir dentro de package; puede que no contenga separadores de ruta y que no tenga subrecursos (es decir, no puede ser un directorio). encoding y errors tienen el mismo significado que conopen()
integrado. Esta función retorna el contenido del recurso comostr
.Obsoleto desde la versión 3.11: Las llamadas a esta función se pueden reemplazar por:
files(package).joinpath(resource).read_text(encoding=encoding)
- importlib.resources.path(package, resource)¶
Retorna la ruta al resource como una ruta real del sistema de archivos. Esta función retorna un administrador de contexto para usar en una declaración
with
. El administrador de contexto proporciona un objetopathlib.Path
.Al salir del administrador de contexto, se limpia cualquier archivo temporal creado cuando se necesita extraer el recurso, p. ej: un archivo comprimido.
package es un nombre o un objeto de módulo que cumple con los requisitos de
Package
. resource es el nombre del recurso para abrir dentro de package; puede que no contenga separadores de ruta y que no tenga subrecursos (es decir, no puede ser un directorio).Obsoleto desde la versión 3.11: Las llamadas a esta función se pueden reemplazar usando
as_file()
:as_file(files(package).joinpath(resource))
- importlib.resources.is_resource(package, name)¶
Retorna
True
si hay un recurso llamado name en el paquete, de lo contrario,False
. Esta función no considera los directorios como recursos. package es un nombre o un objeto de módulo que cumple con los requisitos dePackage
.Obsoleto desde la versión 3.11: Las llamadas a esta función se pueden reemplazar por:
files(package).joinpath(resource).is_file()
- importlib.resources.contents(package)¶
Retorna un iterable sobre los elementos nombrados dentro del paquete. El iterable retorna recursos
str
(por ejemplo, archivos) y no recursos (por ejemplo, directorios). El iterable no recurre a subdirectorios.package es un nombre o un objeto de módulo que cumple con los requisitos de
Package
.Obsoleto desde la versión 3.11: Las llamadas a esta función se pueden reemplazar por:
(resource.name for resource in files(package).iterdir() if resource.is_file())