marshal
— Internal Python object serialization¶
This module contains functions that can read and write Python values in a binary format. The format is specific to Python, but independent of machine architecture issues (e.g., you can write a Python value to a file on a PC, transport the file to a Mac, and read it back there). Details of the format are undocumented on purpose; it may change between Python versions (although it rarely does). [1]
Este no es un módulo general de «persistencia». Para la persistencia general y la transferencia de objetos Python a través de llamadas RPC, consulte los módulos pickle
y shelve
. El módulo marshal
existe principalmente para admitir la lectura y escritura del código «pseudocompilado» para los módulos Python de archivos .pyc
. Por lo tanto, los mantenedores de Python se reservan el derecho de modificar el formato de cálculo de referencias de manera incompatible hacia atrás en caso de necesidad. Si va a serializar y deserializar objetos Python, utilice el módulo pickle
en su lugar: el rendimiento es comparable, la independencia de la versión está garantizada y pickle admite una gama sustancialmente más amplia de objetos que marshal.
Advertencia
El módulo marshal
no está destinado a ser seguro contra datos erróneos o construidos maliciosamente. Nunca deserializar con marshal los datos recibidos de una fuente no confiable o no autenticada.
Not all Python object types are supported; in general, only objects whose value
is independent from a particular invocation of Python can be written and read by
this module. The following types are supported: booleans, integers, floating-point
numbers, complex numbers, strings, bytes, bytearrays, tuples, lists, sets,
frozensets, dictionaries, and code objects, where it should be understood that
tuples, lists, sets, frozensets and dictionaries are only supported as long as
the values contained therein are themselves supported. The
singletons None
, Ellipsis
and StopIteration
can also be
marshalled and unmarshalled.
For format version lower than 3, recursive lists, sets and dictionaries cannot
be written (see below).
Hay funciones que leen/escriben archivos, así como funciones que operan en objetos similares a bytes.
El módulo define estas funciones:
- marshal.dump(value, file[, version])¶
Escribe el valor en el archivo abierto. El valor debe ser un tipo admitido. El archivo debe ser un archivo binary file en el que se pueda escribir.
Si el valor tiene (o contiene un objeto que tiene) un tipo no admitido, se produce una excepción
ValueError
— pero los datos no utilizados también se escribirán en el archivo. El objeto no será leído correctamente porload()
.El argumento version indica el formato de datos que
dump
debe usar (véase más adelante).Lanza un evento de auditoría
marshal.dumps
con argumentosvalue
,version
.
- marshal.load(file)¶
Lee un valor del archivo abierto y lo retorna. Si no se lee ningún valor válido (por ejemplo, porque los datos tienen un formato de cálculo de referencias incompatible de una versión de Python diferente), lanza una excepción
EOFError
,ValueError
oTypeError
. El archivo debe ser un binary file habilitado para lectura.Lanza un evento de auditoría
marshal.load
sin argumentos.Nota
Si un objeto que contiene un tipo no admitido se calcula con
dump()
,load()
sustituiráNone
por el tipo «unmarshallable».Distinto en la versión 3.10: Esta llamada solía lanzar un evento de auditoría
code.__new__
para cada objeto código. Ahora lanza un único eventomarshal.load
para toda la operación de carga.
- marshal.dumps(value[, version])¶
Retorna el objeto bytes que se escribiría en un archivo mediante
dump(value, file)
. El valor debe ser un tipo admitido. Lanza una excepciónValueError
sivalue
tiene (o contiene un objeto que tiene) un tipo no admitido.El argumento version indica el formato de datos que
dumps
debe usar (véase más adelante).Lanza un evento de auditoría
marshal.dumps
con argumentosvalue
,version
.
- marshal.loads(bytes)¶
Convierte el objeto bytes-like object en un valor. Si no se encuentra ningún valor válido, lanza una excepción
EOFError
,ValueError
oTypeError
. Se omiten los bytes adicionales de la entrada.Lanza un evento de auditoría
marshal.loads
con argumentobytes
.Distinto en la versión 3.10: Esta llamada solía lanzar un evento de auditoría
code.__new__
para cada objeto código. Ahora lanza un único eventomarshal.loads
para toda la operación de carga.
Además, se definen las siguientes constantes:
- marshal.version¶
Indicates the format that the module uses. Version 0 is the historical format, version 1 shares interned strings and version 2 uses a binary format for floating-point numbers. Version 3 adds support for object instancing and recursion. The current version is 4.
Notas al pie