zipimport — Zip 저장소에서 모듈 임포트


이 모듈은 파이썬 모듈(*.py, *.pyc)과 패키지를 ZIP-형식 저장소에서 임포트하는 기능을 추가합니다. 일반적으로 zipimport 모듈을 명시적으로 사용할 필요는 없습니다; ZIP 저장소 경로가 sys.path 항목에 있으면 내장 import 메커니즘에 의해 자동으로 사용됩니다.

일반적으로, sys.path는 문자열 디렉터리 이름의 리스트입니다. 이 모듈은 또한 sys.path 항목이 ZIP 파일 저장소를 명명하는 문자열이 될 수 있도록 합니다. ZIP 저장소에는 패키지 임포트를 지원하는 하위 디렉터리 구조가 포함될 수 있으며, 저장소 내의 경로를 지정하여 하위 디렉터리에서만 임포트 되도록 할 수 있습니다. 예를 들어, 경로 example.zip/lib/는 저장소 내의 lib/ 서브 디렉터리에서만 임포트하도록 합니다.

모든 파일이 ZIP 저장소에 있을 수 있지만, .py.pyc 파일만 임포트 할 수 있습니다. 동적 모듈(.pyd, .so)의 ZIP 임포트는 허용되지 않습니다. 저장소에 .py 파일만 포함되어있으면, 파이썬은 해당 .pyc 파일을 추가하여 저장소를 수정하지 않습니다. 즉, ZIP 저장소에 .pyc 파일이 포함되어 있지 않으면, 임포트가 다소 느릴 수 있습니다.

저장소 주석이 포함된 ZIP 저장소는 현재 지원되지 않습니다.

더 보기

PKZIP Application Note

사용된 형식과 알고리즘 저자인 Phil Katz의 ZIP 파일 형식에 관한 설명서.

PEP 273 - Zip 저장소에서 모듈 임포트

구현도 제공한 James C. Ahlstrom이 작성했습니다. 파이썬 2.3은 PEP 273의 명세를 따르지만, Just van Rossum이 작성한 구현을 사용하는데 PEP 302에 설명된 임포트 훅을 사용합니다.

PEP 302 - 새 임포트 훅

이 모듈이 작동하는 데 도움이 되는 임포트 훅을 추가하는 PEP.

이 모듈은 예외를 정의합니다:

exception zipimport.ZipImportError

zipimporter 객체가 발생시키는 예외. ImportError의 서브 클래스이므로, ImportError로도 잡힐 수 있습니다.

zipimporter 객체

zipimporter는 ZIP 파일을 임포트하는 클래스입니다.

class zipimport.zipimporter(archivepath)

새로운 zipimporter 인스턴스를 만듭니다. archivepath는 ZIP 파일의 경로이거나, ZIP 파일 내의 특정 경로여야 합니다. 예를 들어, archivepath foo/bar.zip/lib는 ZIP 파일 foo/bar.zip 내의 lib 디렉터리에 있는 모듈을 찾습니다 (존재한다면).

archivepath가 유효한 ZIP 저장소를 가리키지 않으면 ZipImportError가 발생합니다.

find_module(fullname[, path])

fullname로 지정된 모듈을 검색합니다. fullname은 완전히 정규화된 (점으로 구분된) 모듈 이름이어야 합니다. 모듈이 발견되면 zipimporter 인스턴스 자체를 반환하고, 그렇지 않으면 None을 반환합니다. 선택적 path 인자는 무시됩니다—임포터 프로토콜과의 호환성을 위해 있습니다.

get_code(fullname)

지정된 모듈의 코드 객체를 반환합니다. 모듈을 찾을 수 없으면 ZipImportError를 발생시킵니다.

get_data(pathname)

pathname와 관련된 데이터를 반환합니다. 파일을 찾을 수 없으면 OSError를 발생시킵니다.

버전 3.3에서 변경: OSError 대신 IOError 를 발생시켜왔습니다.

get_filename(fullname)

지정한 모듈이 임포트될 때 설정될 __file__의 값을 반환합니다. 모듈을 찾을 수 없으면 ZipImportError를 발생시킵니다.

버전 3.1에 추가.

get_source(fullname)

지정된 모듈의 소스 코드를 반환합니다. 모듈을 찾을 수 없으면 ZipImportError를 발생시키고, 저장소에 모듈이 있지만, 소스가 없으면 None을 반환합니다.

is_package(fullname)

fullname으로 지정된 모듈이 패키지면 True를 반환합니다. 모듈을 찾을 수 없으면 ZipImportError를 발생시킵니다.

load_module(fullname)

fullname으로 지정된 모듈을 로드 합니다. fullname은 완전히 정규화된 (점으로 구분된) 모듈 이름이어야 합니다. 임포트 된 모듈을 반환하거나, 찾지 못하면 ZipImportError를 발생시킵니다.

archive

있을 수도 있는 하위 경로를 제외한, 임포터와 연결된 ZIP 파일의 파일 이름.

prefix

모듈이 검색되는 ZIP 파일 내의 하위 경로. ZIP 파일의 루트를 가리키는 zipimporter 객체에서는 빈 문자열입니다.

archiveprefix 어트리뷰트는, 슬래시로 결합 될 때, zipimporter 생성자에 지정된 원래 archivepath 인자와 같습니다.

예제

다음은 ZIP 저장소에서 모듈을 임포트하는 예제입니다 - zipimport 모듈이 명시적으로 사용되지 않음에 유의하십시오.

$ 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'