pkgutil
— Utilidad de extensión de paquete¶
Código fuente: Lib/pkgutil.py
Este módulo proporciona utilidades para el sistema de importación, en particular soporte para paquetes.
-
class
pkgutil.
ModuleInfo
(module_finder, name, ispkg)¶ Una tupla nombrada que contiene un breve resumen de la información del módulo.
Nuevo en la versión 3.6.
-
pkgutil.
extend_path
(path, name)¶ Extiende la ruta de búsqueda de los módulos que componen un paquete. El uso previsto es colocar el siguiente código en
__init__.py
: de un paquete:from pkgutil import extend_path __path__ = extend_path(__path__, __name__)
This will add to the package’s
__path__
all subdirectories of directories onsys.path
named after the package. This is useful if one wants to distribute different parts of a single logical package as multiple directories.También busca archivos
*.pkg
donde*
coincide con el argumento name. Esta característica es similar a archivos*.pth
(vea el módulosite
para más información) excepto que no incluye líneas de casos especiales que comienzan conìmport
. Un archivo*.pkg
es confiable al pie de la letra: además de buscar duplicados, todas las entradas encontradas en un*.pkg
se agregan a la ruta, independientemente de si existen en el sistema de archivos. (Esto es una funcionalidad).Si la ruta de entrada no es una lista (como es el caso de los paquetes congelados), se retorna sin cambios. La ruta de entrada no se modifica; se retorna una copia ampliada. Los elementos solo se adjuntan a la copia al final.
Se supone que
sys.path
es una secuencia. Los elementos desys.path
que no sean cadenas de caracteres que se refieran a directorios existentes se ignoran. Los elementos Unicode ensys.path
que causan errores cuando se utilizan como nombres de archivo pueden hacer que esta función lance una excepción (en línea con el comportamiento deos.path.isdir()
).
-
class
pkgutil.
ImpImporter
(dirname=None)¶ Buscador PEP 302 que envuelve el algoritmo de importación «clásico» de Python.
Si dirname es una cadena de caracteres, se crea un buscador PEP 302 que busca ese directorio. Si dirname es
None
, se crea un buscador PEP 302 que busca en el actualsys.path
, más cualquier módulo que esté congelado o incorporado.Tenga en cuenta que
ImpImporter
no admite actualmente el uso de ubicaciónsys.meta_path
.
-
class
pkgutil.
ImpLoader
(fullname, file, filename, etc)¶ Loader que envuelve el algoritmo de importación «clásico» de Python.
-
pkgutil.
find_loader
(fullname)¶ Recupera un módulo loader para un fullname dado.
Este es un contenedor de compatibilidad con versiones anteriores de
importlib.util.find_spec()
que convierte la mayoría de los errores enImportError
y solo retorna el cargador en lugar del completoModuleSpec
.Distinto en la versión 3.3: Actualizado para basarse directamente en
importlib
en lugar de depender del paquete interno PEP 302 emulación de importación.Distinto en la versión 3.4: Actualizado basado en PEP 451
-
pkgutil.
get_importer
(path_item)¶ Recupera un finder para el path_item.
El buscador retornado se almacena en caché en
sys.path_importer_cache
si fue creado recientemente por un enlace de ruta.La caché (o parte de ella) puede ser borrada manualmente si el escaneo de
sys.path_hooks
es necesario.
-
pkgutil.
get_loader
(module_or_name)¶ Obtiene un objeto loader para module_or_name.
Si se puede acceder al módulo o paquete a través del mecanismo de importación normal, se devuelve un contenedor alrededor de la parte relevante de esa maquinaria. Retorna
None
si el módulo no se puede encontrar o importar. Si el módulo nombrado aún no se ha importado, se importa el paquete que lo contiene (si lo hay), para establecer el paquete__path__
.Distinto en la versión 3.3: Actualizado para basarse directamente en
importlib
en lugar de depender del paquete interno PEP 302 emulación de importación.Distinto en la versión 3.4: Actualizado basado en PEP 451
-
pkgutil.
iter_importers
(fullname='')¶ Cede (yield) objetos finder para el nombre de módulo dado.
If fullname contains a
'.'
, the finders will be for the package containing fullname, otherwise they will be all registered top level finders (i.e. those on bothsys.meta_path
andsys.path_hooks
).Si el módulo nombrado está en un paquete, ese paquete se importa como un efecto secundario de invocar esta función.
Si no se especifica ningún nombre de módulo, se generan todos los buscadores de nivel superior.
-
pkgutil.
iter_modules
(path=None, prefix='')¶ Yields
ModuleInfo
for all submodules on path, or, if path isNone
, all top-level modules onsys.path
.path tendría que ser
None
o una list de rutas en las que buscar módulos.prefix es una cadena para mostrar delante de cada nombre de módulo en la salida.
Nota
Sólo funciona para un finder que define un método
iter_modules()
. Esta interfaz no es estándar, por lo que el módulo también proporciona implementaciones paraimportlib.machinery.FileFinder
yzipimport.zipimporter
.
-
pkgutil.
walk_packages
(path=None, prefix='', onerror=None)¶ Cede (yield)
ModuleInfo
para todos los módulos de forma recursiva en path, o, si path esNone
, todos los módulos accesibles.path tendría que ser
None
o una list de rutas en las que buscar módulos.prefix es una cadena para mostrar delante de cada nombre de módulo en la salida.
Note que esta función debe importar todos los packages (¡no todos los módulos!) en el path especificado, para acceder al atributo
__path__
para encontrar submódulos.onerror es una función que se llama con un argumento (el nombre del paquete que se estaba importando) si se produce alguna excepción al intentar importar un paquete. Si no se proporciona ninguna función onerror, los
ImportError
se capturan e ignoran, mientras que todas las demás excepciones se propagan, terminando la búsqueda.Ejemplos:
# list all modules python can access walk_packages() # list all submodules of ctypes walk_packages(ctypes.__path__, ctypes.__name__ + '.')
Nota
Sólo funciona para un finder que define un método
iter_modules()
. Esta interfaz no es estándar, por lo que el módulo también proporciona implementaciones paraimportlib.machinery.FileFinder
yzipimport.zipimporter
.
-
pkgutil.
get_data
(package, resource)¶ Obtiene un recurso de un paquete.
Esto es un contenedor para la API loader
get_data
. El argumento package debe ser el nombre de un paquete, en formato de módulo estándar (foo.bar
).El argumento resource debe tener la forma de un nombre de archivo relativo, utilizando/
como separador de ruta.El nombre del directorio principal..
no está permitido, ni tampoco un nombre raíz (empezando por/
).La función retorna una cadena de caracteres binaria que es el contenido del recurso especificado.
Para los paquetes ubicados en el sistema de archivos, que ya se han importado, este es el equivalente aproximado de:
d = os.path.dirname(sys.modules[package].__file__) data = open(os.path.join(d, resource), 'rb').read()
Si el paquete no puede ser localizado o cargado, o usa un loader el cuál no soporta
get_data
, entonces retornaNone
. En particular, el: término loader para namespace packages no soportaget_data
.
-
pkgutil.
resolve_name
(name)¶ Resuelve un nombre a un objeto.
Esta funcionalidad es usada en numerosos lugares en la librería estándar (ver bpo-12915) - y existe funcionalidad equivalente también en librerías de terceros ampliamente usadas, tales como setuptools, Django y Pyramid.
Se espera que name sea una cadena de caracteres en uno de los siguientes formatos, donde W representa un identificador de Python válido, y un punto representa literalmente un punto en las siguientes pseudo-expresiones regulares:
W(.W)*
W(.W)*:(W(.W)*)?
La primera forma existe sólo para mantener compatibilidad con versiones anteriores. Asume que parte del nombre con puntos es un paquete, y el resto es un objeto en algún lugar dentro de ese paquete, posiblemente anidado dentro de otros objetos. Dado que el lugar donde el paquete termina y la jerarquía de objetos comienza no puede ser inferida por inspección, con esta forma se debe realizar repetidos intentos de importación.
En la segunda forma, el usuario hace claro el punto de división al proveer un signo de dos puntos: el nombre con puntos a la izquierda de los dos puntos es el paquete a ser importado, y el nombre con puntos a la derecha es la jerarquía de nombres dentro de ese paquete. Sólo una importación se necesaria con esta forma. Si termina con dos puntos, entonces se retorna un objeto módulo.
La función retornará un objeto (el cual puede ser un módulo), o lanzará una de las siguientes excepciones:
ValueError
– si name no tiene un formato reconocido.ImportError
– si una importación falló cuando no lo debería haber hecho.AttributeError
– Si un fallo ocurrió mientras se atravesaba la jerarquía de objetos dentro del paquete importado para obtener el objeto deseado.Nuevo en la versión 3.9.