数据编组支持 — Python 文档
数据编组支持
这些例程允许 C 代码使用与 marshal 模块相同的数据格式处理序列化对象。 有将数据写入序列化格式的函数,以及可用于读回数据的附加函数。 用于存储编组数据的文件必须以二进制模式打开。
数值首先以最低有效字节存储。
该模块支持两种版本的数据格式:版本 0 是历史版本,版本 1 共享文件中的内部字符串,以及解组时。 版本 2 对浮点数使用二进制格式。 Py_MARSHAL_VERSION
表示当前文件格式(当前为 2)。
- void PyMarshal_WriteLongToFile(long value, FILE *file, int version)
- 将
long
整数 值 编组到 文件 。 这只会写入 value 的最低有效 32 位; 无论原生long
类型的大小如何。 version 表示文件格式。
- void PyMarshal_WriteObjectToFile(PyObject *value, FILE *file, int version)
- 将 Python 对象 value 编组到 file。 version 表示文件格式。
- 返回包含 值 的编组表示的字节对象。 version 表示文件格式。
以下函数允许读回编组的值。
- long PyMarshal_ReadLongFromFile(FILE *file)
从打开以供读取的
FILE*
中的数据流中返回一个 Clong
。 无论long
的本机大小如何,使用此函数只能读取 32 位值。出错时,设置适当的异常 (EOFError) 并返回
-1
。
- int PyMarshal_ReadShortFromFile(FILE *file)
从打开以供读取的
FILE*
中的数据流中返回一个 Cshort
。 无论short
的本机大小如何,使用此函数只能读取 16 位值。出错时,设置适当的异常 (EOFError) 并返回
-1
。
- PyObject *PyMarshal_ReadObjectFromFile(FILE *file)
从打开以供读取的
FILE*
中的数据流中返回 Python 对象。出错时,设置适当的异常(EOFError、ValueError 或 TypeError)并返回
NULL
。
- PyObject *PyMarshal_ReadLastObjectFromFile(FILE *file)
从打开以供读取的
FILE*
中的数据流中返回 Python 对象。 与 PyMarshal_ReadObjectFromFile() 不同,此函数假定不会从文件中读取更多对象,从而允许它主动将文件数据加载到内存中,以便反序列化可以从内存中的数据进行操作,而不是读取从文件中一次一个字节。 仅当您确定不会从文件中读取任何其他内容时才使用这些变体。出错时,设置适当的异常(EOFError、ValueError 或 TypeError)并返回
NULL
。
- PyObject *PyMarshal_ReadObjectFromString(const char *data, Py_ssize_t len)
从包含 data 指向的 len 字节的字节缓冲区中的数据流返回 Python 对象。
出错时,设置适当的异常(EOFError、ValueError 或 TypeError)并返回
NULL
。