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 par load().

L'argument version indique le format de données que le dump doit utiliser (voir ci-dessous).

Raises an auditing event marshal.dumps with arguments value, 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 ou TypeError 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 » par None.

Modifié dans la version 3.10: This call used to raise a code.__new__ audit event for each code object. Now it raises a single marshal.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 exception ValueError 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 arguments value, version.

marshal.loads(bytes)

Convertit le bytes-like object en une valeur. Si aucune valeur valide n'est trouvée, EOFError, ValueError ou TypeError est levée. Les octets supplémentaires de l'entrée sont ignorés.

Raises an auditing event marshal.loads with argument bytes.

Modifié dans la version 3.10: This call used to raise a code.__new__ audit event for each code object. Now it raises a single marshal.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