zipfile
— Work with ZIP archives¶
Código fuente: Lib/zipfile/
El formato de archivo ZIP es un estándar común de archivo y compresión. Este módulo proporciona herramientas para crear, leer, escribir, agregar y listar un archivo ZIP. Cualquier uso avanzado de este módulo requerirá una comprensión del formato, tal como se define en la PKZIP Application Note.
Actualmente, este módulo no maneja archivos ZIP multi-disco. Puede manejar archivos ZIP que usan las extensiones ZIP64 (es decir, archivos ZIP que tienen más de 4 GB de tamaño). Admite el descifrado de archivos cifrados en archivos ZIP, pero actualmente no puede crear un archivo cifrado. El descifrado es extremadamente lento ya que se implementa en Python nativo en lugar de C.
El módulo define los siguientes elementos:
- exception zipfile.BadZipFile¶
El error lanzado para archivos ZIP incorrectos.
Added in version 3.2.
- exception zipfile.BadZipfile¶
Alias de
BadZipFile
, para compatibilidad con versiones anteriores de Python.Obsoleto desde la versión 3.2.
- exception zipfile.LargeZipFile¶
El error lanzado cuando un archivo ZIP requiera la funcionalidad ZIP64 pero no ha sido habilitado.
- class zipfile.ZipFile
La clase para leer y escribir archivos ZIP. Vea la sección Objetos ZipFile para detalles del constructor.
- class zipfile.Path
Clase que implementa un subconjunto de la interfaz proporcionada por
pathlib.Path
, incluyendo la interfaz completaimportlib.resources.abc.Traversable
.Added in version 3.8.
- class zipfile.PyZipFile
Clase para crear archivos ZIP que contienen bibliotecas de Python.
- class zipfile.ZipInfo(filename='NoName', date_time=(1980, 1, 1, 0, 0, 0))¶
Clase utilizada para representar información sobre un miembro de un archivo. Las instancias de esta clase son retornadas por los métodos
getinfo()
yinfolist()
de objetosZipFile
. La mayoría de los usuarios del módulozipfile
no necesitarán crearlos, sino que solo usarán aquellos creados por este módulo. filename debe ser el nombre completo del miembro del archivo, y date_time debe ser una tupla que contenga seis campos que describan la hora de la última modificación del archivo; los campos se describen en la sección Objetos ZipInfo.Distinto en la versión 3.13: A public
compress_level
attribute has been added to expose the formerly protected_compresslevel
. The older protected name continues to work as a property for backwards compatibility.- _for_archive(archive)¶
Resolve the date_time, compression attributes, and external attributes to suitable defaults as used by
ZipFile.writestr()
.Returns self for chaining.
Added in version 3.14.
- zipfile.is_zipfile(filename)¶
Retorna
True
si filename es un archivo ZIP válido basado en su número mágico; de lo contrario, retornaFalse
. filename también puede ser un archivo o un objeto similar a un archivo.Distinto en la versión 3.1: Soporte para archivos y objetos similares a archivos.
- zipfile.ZIP_STORED¶
La constante numérica para un miembro de archivo sin comprimir.
- zipfile.ZIP_DEFLATED¶
La constante numérica para el método de compresión ZIP habitual. Esto requiere el módulo
zlib
.
- zipfile.ZIP_BZIP2¶
La constante numérica para el método de compresión BZIP2. Esto requiere el módulo
bz2
.Added in version 3.3.
- zipfile.ZIP_LZMA¶
La constante numérica para el método de compresión LZMA. Esto requiere el módulo
lzma
.Added in version 3.3.
Nota
La especificación del formato del archivo ZIP ha incluido soporte para la compresión bzip2 desde 2001 y para la compresión LZMA desde 2006. Sin embargo, algunas herramientas (incluidas las versiones anteriores de Python) no admiten estos métodos de compresión y pueden negarse a procesar el archivo ZIP por completo o no puede extraer archivos individuales.
Ver también
- PKZIP Application Note
Documentación sobre el formato de archivo ZIP por Phil Katz, el creador del formato y los algoritmos utilizados.
- Página principal de Info-ZIP
Información sobre los programas de archivo ZIP del proyecto Info-ZIP y las bibliotecas de desarrollo.
Objetos ZipFile¶
- class zipfile.ZipFile(file, mode='r', compression=ZIP_STORED, allowZip64=True, compresslevel=None, *, strict_timestamps=True, metadata_encoding=None)¶
Abra un archivo ZIP, donde file puede ser una ruta a un archivo (una cadena), un objeto similar a un archivo o un path-like object.
El parámetro mode debe ser
'r'
para leer un archivo existente,'w'
para truncar y escribir un nuevo archivo,'a'
para agregarlo a un archivo existente, o'x'
para crear y escribir exclusivamente un nuevo archivo. Si mode es'x'
y file se refiere a un archivo existente, se lanzará unFileExistsError
. Si mode es'a'
y file se refiere a un archivo ZIP existente, entonces se le agregan archivos adicionales. Si file no se refiere a un archivo ZIP, se agrega un nuevo archivo ZIP al archivo. Esto está destinado a agregar un archivo ZIP a otro archivo (comopython.exe
). Si mode es'a'
y el archivo no existe en absoluto, se crea. Si mode es'r'
o'a'
, el archivo debe poder buscarse.compression es el método de compresión ZIP que se utiliza al escribir el archivo, y debe ser
ZIP_STORED
,ZIP_DEFLATED
,ZIP_BZIP2
oZIP_LZMA
; los valores no reconocidos harán que se lanceNotImplementedError
. SiZIP_DEFLATED
,ZIP_BZIP2
oZIP_LZMA
se especifica pero el módulo correspondiente (zlib
,bz2
olzma
) no está disponible,RuntimeError
es lanzado. El valor predeterminado esZIP_STORED
.Si allowZip64 es
True
(el valor predeterminado) zipfile creará archivos ZIP que usan las extensiones ZIP64 cuando el archivo zip es mayor que 4 GB. Si esFalse
zipfile
lanzará una excepción cuando el archivo ZIP requiera extensiones ZIP64.El parámetro compresslevel controla el nivel de compresión que se utilizará al escribir archivos en el archivo. Cuando se utiliza
ZIP_STORED
oZIP_LZMA
no tiene ningún efecto. Cuando se usaZIP_DEFLATED
se aceptan los enteros0
a9
(verzlib
para más información). Cuando se utilizaZIP_BZIP2
se aceptan enteros1
a9
(consultebz2
para obtener más información).El argumento strictly_timestamps, cuando se establece en
False
, permite comprimir archivos anteriores a 1980-01-01 a costa de establecer la marca de tiempo en 1980-01-01. Un comportamiento similar ocurre con archivos más nuevos que 2107-12-31, la marca de tiempo también se establece en el límite.Cuando el parámetro mode es
'r'
, el metadata_encoding podría ser asignado al nombre del codec, el cual será usado para decodificar metadata como los nombres de los miembros y comentarios ZIP.Si el archivo se crea con el modo
'w'
,'x'
o'a'
y luegoclosed
sin agregar ningún archivo al archivo, Las estructuras ZIP apropiadas para un archivo vacío se escribirán en el archivo.ZipFile también es un manejador de contexto y por lo tanto, admite la declaración
with
. En el ejemplo, myzip se cierra después que el conjunto de instruccioneswith
se termine—incluso si se produce una excepción:with ZipFile('spam.zip', 'w') as myzip: myzip.write('eggs.txt')
Nota
metadata_encoding es una configuración que se aplica a todas las instancias de ZipFile. Actualmente no es posible establecerlo individualmente para cada miembro.
Este atributo es una solución alterna para implementaciones heredadas que producen archivos con nombres basados en la codificación regional o la página de códigos actual (con mayor frecuencia en Windows). De acuerdo con el estándar .ZIP, la codificación de la metadata podría ser especificada por la página de códigos de IBM (por defecto) or por UTF-8 mediante un flag en la cabecera. Este flag toma precedencia sobre metadata_encoding, el cual es una extensión específica a Python.
Distinto en la versión 3.2: Se agregó la capacidad de usar
ZipFile
como administrador de contexto.Distinto en la versión 3.4: Las extensiones ZIP64 están habilitadas por defecto.
Distinto en la versión 3.5: Se agregó soporte para escribir en secuencias que no se pueden buscar. Se agregó soporte para el modo
'x'
.Distinto en la versión 3.6: Anteriormente, se generó un simple
RuntimeError
para valores de compresión no reconocidos.Distinto en la versión 3.6.2: El parámetro file acepta un path-like object.
Distinto en la versión 3.7: Agregue el parámetro compresslevel.
Distinto en la versión 3.8: The strict_timestamps keyword-only parameter.
Distinto en la versión 3.11: Se ha añadido soporte para especificar la codificación del nombre del miembro para leer metadatos en las cabeceras de directorio y archivo del archivo zip.
- ZipFile.close()¶
Cierra el archivo. Debe llamar a
close()
antes de salir de su programa o no se escribirán registros esenciales.
- ZipFile.getinfo(name)¶
Retorna un objeto
ZipInfo
con información sobre el miembro del archivo name. Llamando agetinfo()
para obtener un nombre que no figura actualmente en el archivo lanzará unKeyError
.
- ZipFile.infolist()¶
Retorna una lista que contiene un objeto
ZipInfo
para cada miembro del archivo. Los objetos están en el mismo orden que sus entradas en el archivo ZIP real en el disco si se abrió un archivo existente.
- ZipFile.namelist()¶
Retorna una lista de miembros del archivo por nombre.
- ZipFile.open(name, mode='r', pwd=None, *, force_zip64=False)¶
Acceda a un miembro del archivo comprimido como un objeto binario similar a un archivo. name puede ser el nombre de un archivo dentro del archivo comprimido o un objeto
ZipInfo
. El parámetro mode, si está incluido, debe ser'r'
(el valor predeterminado) o'w'
. pwd es la contraseña utilizada para descifrar archivos ZIP encriptados como un objetobytes
.open()
también es un administrador de contexto y por lo tanto, soportawith
statement
:with ZipFile('spam.zip') as myzip: with myzip.open('eggs.txt') as myfile: print(myfile.read())
Con mode
'r'
, el objeto tipo archivo (ZipExtFile
) es de solo lectura y proporciona los siguientes métodos:read()
,readline()
,readlines()
,seek()
,tell()
,__iter__()
,__ next__()
. Estos objetos pueden funcionar independientemente del archivo Zip.Con
mode = 'w'
, se retorna un controlador de archivo escribible, que admite el métodowrite()
. Mientras está abierto un identificador de archivo escribible, intentar leer o escribir otros archivos en el archivo ZIP lanzará unValueError
.In both cases the file-like object has also attributes
name
, which is equivalent to the name of a file within the archive, andmode
, which is'rb'
or'wb'
depending on the input mode.Al escribir un archivo, si el tamaño del archivo no se conoce de antemano pero puede exceder los 2 GB, pase
force_zip64 = True
para asegurarse de que el formato del encabezado sea capaz de admitir archivos grandes. Si el tamaño del archivo se conoce de antemano, construya un objetoZipInfo
confile_size
establecido, y úselo como parámetro name.Nota
Los métodos
open()
,read()
yextract()
pueden tomar un nombre de archivo o un objetoZipInfo
. Apreciará esto cuando intente leer un archivo ZIP que contiene miembros con nombres duplicados.Distinto en la versión 3.6: Se eliminó el soporte de
mode='U'
. Useio.TextIOWrapper
para leer archivos de texto comprimido en modo universal newlines.Distinto en la versión 3.6:
ZipFile.open()
ahora se puede usar para escribir archivos en el archivo comprimido con la opciónmode='w'
.Distinto en la versión 3.6: Llamar a
open()
en un ZipFile cerrado lanzará unValueError
. Anteriormente, se planteó aRuntimeError
.Distinto en la versión 3.13: Added attributes
name
andmode
for the writeable file-like object. The value of themode
attribute for the readable file-like object was changed from'r'
to'rb'
.
- ZipFile.extract(member, path=None, pwd=None)¶
Extraer un miembro del archivo comprimido al directorio de trabajo actual; member debe ser su nombre completo o un objeto
ZipInfo
. La información de su archivo se extrae con la mayor precisión posible. path especifica un directorio diferente para extraer. member puede ser un nombre de archivo o un objetoZipInfo
. pwd es la contraseña utilizada para archivos encriptados como un objetobytes
.Retorna la ruta normalizada creada (un directorio o archivo nuevo).
Nota
Si el nombre de archivo de un miembro es una ruta absoluta, se eliminarán un punto compartido de
drive/UNC
y las barras diagonales (hacia atrás), ej:///foo/bar
se convierte enfoo/bar
en Unix yC:\foo\bar
se convierte enfoo\bar
en Windows. Y todos los componentes".."
en un nombre de archivo miembro se eliminarán, ej:../../foo../../ba..r
se convierte enfoo../ba..r
. En Windows, los caracteres ilegales (:
,<
,>
,|
,"
,?
Y*
) se reemplazan por guion bajo (_
).Distinto en la versión 3.6: Llamando
extract()
en un ZipFile cerrado lanzará unValueError
. Anteriormente, se planteó aRuntimeError
.Distinto en la versión 3.6.2: El parámetro path acepta un path-like object.
- ZipFile.extractall(path=None, members=None, pwd=None)¶
Extrae todos los miembros del archivo comprimido al directorio de trabajo actual. path especifica un directorio diferente para extraer. members es opcional y debe ser un subconjunto de la lista devuelta por
namelist()
. pwd es la contraseña utilizada para archivos encriptados como un objetobytes
.Advertencia
Nunca extraiga archivos de fuentes no confiables sin inspección previa. Es posible que los archivos se creen fuera de path, ej. miembros que tienen nombres de archivo absolutos que comienzan con
"/"
o nombres de archivo con dos puntos".."
. Este módulo intenta evitar eso. Verextract()
nota.Distinto en la versión 3.6: Llamar a
extractall()
en un ZipFile cerrado lanzará unValueError
. Anteriormente, se planteó aRuntimeError
.Distinto en la versión 3.6.2: El parámetro path acepta un path-like object.
- ZipFile.printdir()¶
Imprime una tabla de contenido para el archivo en
sys.stdout
.
- ZipFile.setpassword(pwd)¶
Establece pwd (un objeto
bytes
) como contraseña predeterminada para extraer archivos encriptados.
- ZipFile.read(name, pwd=None)¶
Retorna los bytes del archivo name en el archivo comprimido. name es el nombre del archivo en el archivo comprimido, o un objeto
ZipInfo
. El archivo comprimido debe estar abierto para lectura o añadidura. pwd es la contraseña utilizada para los archivos encriptados como un objetobytes
y, si se especifica, anula la contraseña predeterminada establecida consetpassword()
. Llamar aread()
en un ZipFile que utiliza un método de compresión que no seaZIP_STORED
,ZIP_DEFLATED
,ZIP_BZIP2
oZIP_LZMA
lanzará unNotImplementedError
. También se lanzará un error si el módulo de compresión correspondiente no está disponible.Distinto en la versión 3.6: Llamando
read()
en un ZipFile cerrado lanzará unValueError
. Anteriormente, se planteó aRuntimeError
.
- ZipFile.testzip()¶
Lee todos los archivos en el archivo y verifica sus CRC y encabezados de archivo. Retorna el nombre del primer archivo incorrecto o retorna
None
.Distinto en la versión 3.6: Llamar a
testzip()
en un ZipFile cerrado lanzará unValueError
. Anteriormente, se planteó aRuntimeError
.
- ZipFile.write(filename, arcname=None, compress_type=None, compresslevel=None)¶
Escribe el archivo llamado filename en el archivo, dándole el nombre de archivo arcname (por defecto, será el mismo que filename, pero sin una letra de unidad y con los separadores de ruta principales eliminados). Si se proporciona, compress_type anula el valor dado para el parámetro compression al constructor para la nueva entrada. Del mismo modo, compresslevel anulará el constructor si se proporciona. El archivo debe estar abierto con el modo
'w'
,'x'
o'a'
.Nota
Históricamente, el estándar del archivo ZIP no especificaba una codificación para la metadata, pero si era fuertemente recomendado usar CP437(la codificación original de IBM PC) con fines de interoperabilidad. Versiones recientes permiten el uso de UTF-8 (exclusivamente). En éste modulo, UTF-8 será usada automáticamente para escribir los nombres de los miembros si es que estos contienen algún caracter no-ASCII. No es posible escribir nombres de miembros en otra codificación que no sea ASCII o UTF-8.
Nota
Los nombres de archivo deben ser relativos a la raíz del archivo, es decir, no deben comenzar con un separador de ruta.
Nota
Si
arcname
(ofilename
, siarcname
no se proporciona) contiene un byte nulo, el nombre del archivo en el archivo se truncará en el byte nulo.Nota
Un barra al frente en el nombre del archivo puede hacer que el archivo sea imposible de abrir en algunos programas zip en sistemas Windows.
Distinto en la versión 3.6: Llamando
write()
en un ZipFile creado con el modo'r'
o un ZipFile cerrado lanzará unValueError
. Anteriormente, se planteó aRuntimeError
.
- ZipFile.writestr(zinfo_or_arcname, data, compress_type=None, compresslevel=None)¶
Escribe un registro en el archivo. El contenido es data, que puede ser una instancia de
str
o abytes
; si es unastr
, primero se codifica como UTF-8. zinfo_or_arcname es el nombre del archivo que se le dará en el archivo o una instancia deZipInfo
. Si se trata de una instancia, se debe proporcionar al menos el nombre de archivo, la fecha y la hora. Si es un nombre, la fecha y la hora se configuran en la fecha y hora actuales. El archivo debe abrirse con el modo'w'
,'x'
o'a'
.Si se proporciona, compress_type anula el valor dado para el parámetro compression al constructor para la nueva entrada, o en zinfo_or_arcname (si es una instancia de
ZipInfo
). Del mismo modo, compresslevel anulará el constructor si se proporciona.Nota
Al pasar una instancia de
ZipInfo
como el parámetro zinfo_or_arcname, el método de compresión utilizado será el especificado en el miembro compress_type de la instancia dadaZipInfo
. Por defecto, el constructorZipInfo
establece este miembro enZIP_STORED
.Distinto en la versión 3.2: El argumento compress_type.
Distinto en la versión 3.6: Llamando
writestr()
en un ZipFile creado con el modo'r'
o un ZipFile cerrado lanzará unValueError
. Anteriormente, se planteó aRuntimeError
.
- ZipFile.mkdir(zinfo_or_directory, mode=511)¶
Crea un directorio dentro del archivo. Si zinfo_or_directory es un string, el directorio es creado dentro del archivo con el modo especificado en el argumento mode. Si del contrario, zinfo_or_directory es una instancia de
ZipInfo
entonces el argumento mode es ignorado.El archivo debe estar abierto en modo
'w'
,'x'
o'a'
.Added in version 3.11.
Los siguientes atributos de datos también están disponibles:
- ZipFile.filename¶
Nombre del archivo ZIP.
- ZipFile.debug¶
El nivel de salida de depuración a usar. Esto se puede configurar de
0
(el valor predeterminado, sin salida) a3
(la mayor cantidad de salida). La información de depuración se escribe ensys.stdout
.
Objetos de ruta¶
- class zipfile.Path(root, at='')¶
Construye un objeto Path a partir de un archivo zip
root
(que puede ser una instanciaZipFile
ofile
adecuado para pasar al constructorZipFile
).at
especifica la ubicación de esta ruta dentro del archivo zip, ej. “dir/file.txt”, “dir/” o “”.El valor predeterminado es la cadena vacía, que indica la raíz.
Los objetos de ruta exponen las siguientes características de objetos pathlib.Path
:
Los objetos de ruta son transitables utilizando el operador /
o utilizando joinpath
.
- Path.name¶
El componente final de la ruta.
- Path.open(mode='r', *, pwd, **)¶
Invoca
ZipFile.open()
en la ruta actual. Permite la apertura para lectura o escritura, texto o binario a través de los modos admitidos: “r”, “w”, “rb”, “wb”. Los argumentos posicionales y de palabras clave se pasan a través deio.TextIOWrapper
cuando se abren como texto y se ignoran en caso contrario.pwd
es el parámetropwd
paraZipFile.open()
.Distinto en la versión 3.9: Se agregó soporte para modos de texto y binarios para abrir. El modo predeterminado ahora es texto.
Distinto en la versión 3.11.2: El parámetro
encoding
puede proporcionarse como un argumento posicional sin causar unTypeError
. Tal y como podía ocurrir en la versión 3.9. El código que necesite ser compatible con versiones no parcheadas 3.10 y 3.11 debe pasar como palabras clave todos los argumentos deio.TextIOWrapper
, incluidoencoding
.
- Path.iterdir()¶
Enumera los hijos del directorio actual.
- Path.is_dir()¶
Retorna
True
si el contexto actual hace referencia a un directorio.
- Path.is_file()¶
Retorna
True
si el contexto actual hace referencia a un archivo.
- Path.is_symlink()¶
Return
True
if the current context references a symbolic link.Added in version 3.12.
Distinto en la versión 3.13: Previously,
is_symlink
would unconditionally returnFalse
.
- Path.exists()¶
Retorna
True
si el contexto actual hace referencia a un archivo o directorio en el archivo zip.
- Path.suffix¶
The last dot-separated portion of the final component, if any. This is commonly called the file extension.
Added in version 3.11: Propiedad agregada
Path.suffix
.
- Path.stem¶
El componente final de la ruta, sin su sufijo.
Added in version 3.11: Propiedad agregada
Path.stem
.
- Path.suffixes¶
A list of the path’s suffixes, commonly called file extensions.
Added in version 3.11: Propiedad agregada
Path.suffixes
.
- Path.read_text(*, **)¶
Lee el archivo actual como texto unicode. Los argumentos posicionales y de palabras clave se pasan a
io.TextIOWrapper
(exceptobuffer
, que está implícito en el contexto).Distinto en la versión 3.11.2: El parámetro
encoding
puede proporcionarse como un argumento posicional sin causar unTypeError
. Tal y como podía ocurrir en la versión 3.9. El código que necesite ser compatible con versiones no parcheadas 3.10 y 3.11 debe pasar como palabras clave todos los argumentos deio.TextIOWrapper
, incluidoencoding
.
- Path.read_bytes()¶
Lee el archivo actual como bytes.
- Path.joinpath(*other)¶
Retorna un nuevo objeto de ruta con cada argumentos other unidos. Los siguientes son equivalentes:
>>> Path(...).joinpath('child').joinpath('grandchild') >>> Path(...).joinpath('child', 'grandchild') >>> Path(...) / 'child' / 'grandchild'
Distinto en la versión 3.10: Antes de 3.10,
joinpath
no estaba documentado y aceptaba exactamente un parámetro.
The zipp project provides backports
of the latest path object functionality to older Pythons. Use
zipp.Path
in place of zipfile.Path
for early access to
changes.
Objetos PyZipFile¶
El constructor PyZipFile
toma los mismos parámetros que el constructor ZipFile
, y un parámetro adicional, optimize.
- class zipfile.PyZipFile(file, mode='r', compression=ZIP_STORED, allowZip64=True, optimize=-1)¶
Distinto en la versión 3.2: Added the optimize parameter.
Distinto en la versión 3.4: Las extensiones ZIP64 están habilitadas por defecto.
Las instancias tienen un método ademas de los objetos
ZipFile
:- writepy(pathname, basename='', filterfunc=None)¶
Busca archivos
*.py
y agrega el archivo correspondiente al archivo.Si no se proporcionó el parámetro optimize a
PyZipFile
o-1
, el archivo correspondiente es un archivo*.pyc
, compilando si es necesario.Si el parámetro optimize a
PyZipFile
era0
,1
or2
, solo se agregarán a ese archivo los archivos con ese nivel de optimización (vercompile()
) el archivo, compilando si es necesario.Si pathname es un archivo, el nombre del archivo debe terminar con
.py
, y solo el archivo (correspondiente*.pyc
) se agrega en el nivel superior (sin información de ruta). Si pathname es un archivo que no termina con.py
, se lanzaráRuntimeError
. Si es un directorio, y el directorio no es un directorio de paquetes, entonces todos los archivos*.pyc
se agregan en el nivel superior. Si el directorio es un directorio de paquetes, todos*.pyc
se agregan bajo el nombre del paquete como una ruta de archivo, y si alguno de los subdirectorios son directorios de paquetes, todos estos se agregan recursivamente en orden ordenado.basename está destinado solo para uso interno.
filterfunc, si se proporciona, debe ser una función que tome un único argumento de cadena. Se le pasará cada ruta (incluida cada ruta de archivo completa individual) antes de que se agregue al archivo. Si filterfunc retorna un valor falso, la ruta no se agregará y si se trata de un directorio se ignorará su contenido. Por ejemplo, si nuestros archivos de prueba están todos en directorios de
test
o comienzan con la cadenatest_
, podemos usar un filterfunc para excluirlos>>> zf = PyZipFile('myprog.zip') >>> def notests(s): ... fn = os.path.basename(s) ... return (not (fn == 'test' or fn.startswith('test_'))) ... >>> zf.writepy('myprog', filterfunc=notests)
El método
writepy()
crea archivos con nombres de archivo como estestring.pyc # Top level name test/__init__.pyc # Package directory test/testall.pyc # Module test.testall test/bogus/__init__.pyc # Subpackage directory test/bogus/myfile.pyc # Submodule test.bogus.myfile
Distinto en la versión 3.4: Added the filterfunc parameter.
Distinto en la versión 3.6.2: El parámetro pathname acepta un path-like object.
Distinto en la versión 3.7: La recursividad ordena las entradas del directorio.
Objetos ZipInfo¶
Las instancias de la clase ZipInfo
son retornadas por los métodos getinfo()
y infolist()
de ZipFile
. Cada objeto almacena información sobre un solo miembro del archivo ZIP.
Hay un método de clase para hacer una instancia de ZipInfo
para un archivo de sistema de archivos:
- classmethod ZipInfo.from_file(filename, arcname=None, *, strict_timestamps=True)¶
Construye una instancia de
ZipInfo
para un archivo en el sistema de archivos, en preparación para agregarlo a un archivo zip.filename debe ser la ruta a un archivo o directorio en el sistema de archivos.
Si se especifica arcname, este es usado como el nombre dentro del archivo. Si no se especifica arcname, el nombre será el mismo que filename, pero con cualquier letra de unidad y separadores de ruta principales eliminados.
El argumento strictly_timestamps, cuando se establece en
False
, permite comprimir archivos anteriores a 1980-01-01 a costa de establecer la marca de tiempo en 1980-01-01. Un comportamiento similar ocurre con archivos más nuevos que 2107-12-31, la marca de tiempo también se establece en el límite.Added in version 3.6.
Distinto en la versión 3.6.2: El parámetro filename acepta un path-like object.
Distinto en la versión 3.8: Added the strict_timestamps keyword-only parameter.
Las instancias tienen los siguientes métodos y atributos:
- ZipInfo.is_dir()¶
Retorna
True
si este miembro del archivo es un directorio.Utiliza el nombre de la entrada: los directorios siempre deben terminar con
/
.Added in version 3.6.
- ZipInfo.filename¶
Nombre del archivo en el archivo.
- ZipInfo.date_time¶
La hora y fecha de la última modificación al miembro del archivo. Esta es una tupla de seis valores:
Índice
Valor
0
Año (>= 1980)
1
Mes (basado en uno)
2
Día del mes (basado en uno)
3
Horas (basados en cero)
4
Minutos (basados en cero)
5
Segundos (basado en cero)
Nota
El formato de archivo ZIP no admite marcas de tiempo anteriores a 1980.
- ZipInfo.compress_type¶
Tipo de compresión para la miembro del archivo.
- ZipInfo.extra¶
Datos de campo de expansión. La PKZIP Application Note contiene algunos comentarios sobre la estructura interna de los datos contenidos en este objeto
bytes
.
- ZipInfo.create_system¶
Sistema que creó el archivo ZIP.
- ZipInfo.create_version¶
Versión PKZIP que creó el archivo ZIP.
- ZipInfo.extract_version¶
Se necesita la versión PKZIP para extraer el archivo.
- ZipInfo.reserved¶
Debe ser cero.
- ZipInfo.flag_bits¶
Bits de bandera ZIP.
- ZipInfo.volume¶
Número de volumen del encabezado del archivo.
- ZipInfo.internal_attr¶
Atributos internos.
- ZipInfo.external_attr¶
Atributos de archivo externo.
- ZipInfo.header_offset¶
Byte desplazado al encabezado del archivo.
- ZipInfo.CRC¶
CRC-32 del archivo sin comprimir.
- ZipInfo.compress_size¶
Tamaño de los datos comprimidos.
- ZipInfo.file_size¶
Tamaño del archivo sin comprimir.
Interfaz de línea de comandos¶
El módulo zipfile
proporciona una interfaz de línea de comandos simple para interactuar con archivos ZIP.
Si desea crear un nuevo archivo ZIP, especifique su nombre después de la opción -c
y luego enumere los nombres de archivo que deben incluirse:
$ python -m zipfile -c monty.zip spam.txt eggs.txt
Pasar un directorio también es aceptable:
$ python -m zipfile -c monty.zip life-of-brian_1979/
Si desea extraer un archivo ZIP en el directorio especificado, use la opción -e
:
$ python -m zipfile -e monty.zip target-dir/
Para obtener una lista de los archivos en un archivo ZIP, use la opción -l
:
$ python -m zipfile -l monty.zip
Opciones de línea de comando¶
- -c <zipfile> <source1> ... <sourceN>¶
- --create <zipfile> <source1> ... <sourceN>¶
Crea el archivo zip a partir de archivos fuente.
Problemas de descompresión¶
La extracción en el módulo zipfile puede fallar debido a algunos problemas que se enumeran a continuación.
Del archivo mismo¶
La descompresión puede fallar debido a una contraseña incorrecta / suma de verificación CRC / formato ZIP o método / descifrado de compresión no compatible.
Limitaciones del sistema de archivos¶
Exceder las limitaciones en diferentes sistemas de archivos puede causar que la descompresión falle. Como los caracteres permitidos en las entradas del directorio, la longitud del nombre del archivo, la longitud de la ruta, el tamaño de un solo archivo y la cantidad de archivos, etc.
Limitaciones de recursos¶
La falta de memoria o volumen de disco conduciría a la descompresión fallida. Por ejemplo, las bombas de descompresión (también conocido como ZIP bomb) se aplican a la biblioteca de archivos zip que pueden causar el agotamiento del volumen del disco.
Interrupción¶
La interrupción durante la descompresión, como presionar control-C o matar el proceso de descompresión, puede dar como resultado una descompresión incompleta del archivo.
Comportamientos predeterminados de extracción¶
No conocer los comportamientos de extracción predeterminados puede causar resultados de descompresión inesperados. Por ejemplo, al extraer el mismo archivo dos veces, sobrescribe los archivos sin preguntar.