31.4. zipimport
— Importer des modules à partir d’archives Zip¶
Nouveau dans la version 2.3.
This module adds the ability to import Python modules (*.py
,
*.py[co]
) and packages from ZIP-format archives. It is usually not
needed to use the zipimport
module explicitly; it is automatically used
by the built-in import
mechanism for sys.path
items that are paths
to ZIP archives.
Typiquement, sys.path
est une liste de noms de répertoires sous forme de chaînes. Ce module permet également à un élément de sys.path
d’être une chaîne nommant une archive de fichier ZIP. L’archive ZIP peut contenir une structure de sous-répertoire pour prendre en charge les importations de paquets, et un chemin dans l’archive peut être spécifié pour importer uniquement à partir d’un sous-répertoire. Par exemple, le chemin d’accès example.zip/lib/
importerait uniquement depuis le sous-répertoire lib/
dans l’archive.
Any files may be present in the ZIP archive, but only files .py
and
.py[co]
are available for import. ZIP import of dynamic modules
(.pyd
, .so
) is disallowed. Note that if an archive only contains
.py
files, Python will not attempt to modify the archive by adding the
corresponding .pyc
or .pyo
file, meaning that if a ZIP archive
doesn’t contain .pyc
files, importing may be rather slow.
Using the built-in reload()
function will fail if called on a module
loaded from a ZIP archive; it is unlikely that reload()
would be needed,
since this would imply that the ZIP has been altered during runtime.
ZIP archives with an archive comment are currently not supported.
Voir aussi
- PKZIP Application Note
Documentation sur le format de fichier ZIP par Phil Katz, créateur du format et des algorithmes utilisés.
- PEP 273 - Import Modules from Zip Archives
Written by James C. Ahlstrom, who also provided an implementation. Python 2.3 follows the specification in PEP 273, but uses an implementation written by Just van Rossum that uses the import hooks described in PEP 302.
- PEP 302 — Nouveaux crochets d’importation
Le PEP pour ajouter les crochets d’importation qui aident ce module à fonctionner.
Ce module définit une exception :
-
exception
zipimport.
ZipImportError
¶ Exception levée par les objets zipimporter. C’est une sous-classe de
ImportError
, donc il peut être pris commeImportError
, aussi.
31.4.1. Objets zimporter¶
zipimporter
est la classe pour importer des fichiers ZIP.
-
class
zipimport.
zipimporter
(archivepath)¶ Créez une nouvelle instance de zipimporter. archivepath doit être un chemin vers un fichier ZIP, ou vers un chemin spécifique dans un fichier ZIP. Par exemple, un archivepath de
foo/bar.zip/lib
cherchera les modules dans le répertoirelib
du fichier ZIPfoo/bar.zip
(si celui-ci existe).ZipImportError
est levée si archivepath ne pointe pas vers une archive ZIP valide.-
find_module
(fullname[, path])¶ Rechercher un module spécifié par fullname. fullname doit être le nom du module entièrement qualifié (dotted). Elle retourne l’instance zipimporter elle-même si le module a été trouvé, ou
None
si ce n’est pas le cas. L’argument optionnel path est ignoré — il est là pour la compatibilité avec le protocole de l’importateur.
-
get_code
(fullname)¶ Retourne l’objet de code pour le module spécifié. Lève
ZipImportError
si le module n’a pas pu être trouvé.
-
get_data
(pathname)¶ Return the data associated with pathname. Raise
IOError
if the file wasn’t found.
-
get_filename
(fullname)¶ Renvoie la valeur
__file____
qui serait définie si le module spécifié était importé. LèveZipImportError
si le module n’a pas pu être trouvé.
Nouveau dans la version 2.7.
-
get_source
(fullname)¶ Renvoie le code source du module spécifié. Lève
ZipImportError
si le module n’a pas pu être trouvé, renvoieNone
si l’archive contient le module, mais n’en a pas la source.
-
is_package
(fullname)¶ Renvoie
True
si le module spécifié par fullname est un paquet. LèveZipImportError
si le module n’a pas pu être trouvé.
-
load_module
(fullname)¶ Charge le module spécifié par fullname. fullname doit être le nom du module entièrement qualifié (dotted). Il renvoie le module importé, ou augmente
ZipImportError
s’il n’a pas été trouvé.
-
archive
¶ Le nom de fichier de l’archive ZIP associé à l’importateur, sans sous-chemin possible.
-
prefix
¶ Le sous-chemin du fichier ZIP où les modules sont recherchés. C’est la chaîne vide pour les objets zipimporter qui pointent vers la racine du fichier ZIP.
Les attributs
archive
etprefix
, lorsqu’ils sont combinés avec une barre oblique, égalent l’argument original archivepath donné au constructeurzipimporter
.-
31.4.2. Exemples¶
Voici un exemple qui importe un module d’une archive ZIP — notez que le module zipimport
n’est pas explicitement utilisé.
$ unzip -l example.zip
Archive: example.zip
Length Date Time Name
-------- ---- ---- ----
8467 11-26-02 22:30 jwzthreading.py
-------- -------
8467 1 file
$ ./python
Python 2.3 (#1, Aug 1 2003, 19:54:32)
>>> import sys
>>> sys.path.insert(0, 'example.zip') # Add .zip file to front of path
>>> import jwzthreading
>>> jwzthreading.__file__
'example.zip/jwzthreading.py'