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]
Ce module ne permet pas de « sérialiser » des objets de manière permanente. Pour des questions de sérialisation en général ou de transfert d'objets Python par des appels RPC, référez-vous aux modules pickle
et shelve
. Le module marshal
existe principalement pour permettre la lecture et l'écriture de code « pseudo-compilé » pour les modules Python des fichiers .pyc
. Par conséquent, les mainteneurs Python se réservent le droit de modifier le format marshal en cassant la rétrocompatibilité si besoin. Si vous sérialisez et dé-sérialisez des objets Python, utilisez plutôt le module pickle
— les performances sont comparables, l'indépendance par rapport à la version est garantie, et pickle prend en charge une gamme d'objets beaucoup plus large que marshal.
Avertissement
N'utilisez pas le module marshal
pour lire des données erronées ou malveillantes. Ne démantelez jamais des données reçues d'une source non fiable ou non authentifiée.
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).
Il existe des fonctions de lecture-écriture de fichiers ainsi que des fonctions opérant sur des objets octet.
Le module définit ces fonctions :
- marshal.dump(value, file[, version])¶
Écrit la valeur sur le fichier ouvert. La valeur doit être un type pris en charge. Le fichier doit être un fichier binaire ouvert en écriture.
Si la valeur est (ou contient un objet qui est) d'un type non implémenté, une exception
ValueError
est levée — mais le contenu de la mémoire sera également écrit dans le fichier. L'objet ne sera pas correctement lu parload()
.L'argument version indique le format de données que le
dump
doit utiliser (voir ci-dessous).Raises an auditing event
marshal.dumps
with argumentsvalue
,version
.
- marshal.load(file)¶
Lit une valeur du fichier ouvert et la renvoie. Si aucune valeur valide n'est lue (p. ex. parce que les données ont un format décompilé incompatible avec une autre version de Python),
EOFError
,ValueError
ouTypeError
est levée. Le fichier doit être un fichier binaire ouvert en lecture.Raises an auditing event
marshal.load
with no arguments.Note
Si un objet contenant un type non pris en charge a été dé-compilé avec
dump()
,load()
remplacera le type non « dé-compilable » parNone
.Modifié dans la version 3.10: This call used to raise a
code.__new__
audit event for each code object. Now it raises a singlemarshal.load
event for the entire load operation.
- marshal.dumps(value[, version])¶
Renvoie les octets qui seraient écrits dans un fichier par
dump(value, file)
. La valeur doit être un type pris en charge. Lève une exceptionValueError
si la valeur a (ou contient un objet qui a) un type qui n'est pas pris en charge.L'argument version indique le format de données que
dumps
doivent utiliser (voir ci-dessous).Raises an auditing event
marshal.dumps
with argumentsvalue
,version
.
- marshal.loads(bytes)¶
Convertit le bytes-like object en une valeur. Si aucune valeur valide n'est trouvée,
EOFError
,ValueError
ouTypeError
est levée. Les octets supplémentaires de l'entrée sont ignorés.Raises an auditing event
marshal.loads
with argumentbytes
.Modifié dans la version 3.10: This call used to raise a
code.__new__
audit event for each code object. Now it raises a singlemarshal.loads
event for the entire load operation.
De plus, les constantes suivantes sont définies :
- 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.
Notes