25

python standard library marshal

 4 years ago
source link: https://pinghailinfeng.gitee.io/2020/02/16/python-standard-library-marshal/
Go to the source link to view the article. You can view the picture content, updated content and better typesetting reading experience. If the link is broken, please click the button below to view the snapshot at that time.

marshal — 内部 Python 对象序列化

vEjIBbu.jpg!web

每日一词:

否极泰来( pi ji tai lai):

否,读如痞(pǐ)又作“否极终泰”、“否去泰来”。天地相交,因而安泰。天与地不相交,叫做否。在这种情况下,君子应该收敛自己的才华,以避免小人陷害;不可追求荣誉富贵,以避免小人嫉妒。闭塞到了极点,则转向通泰。人们将这些观点概括为否极泰来或否极终泰。原指事物发展到一定程度,就要转化到它的对立面。后常以此形容情况从坏变好。

【出典】:

《易·泰》:“天地交,泰。”《易·否》:“天地不交,否;君子以俭德辟难,不可荣以禄。”《易·杂卦》:“否泰反其类也。”

【例句】:

《吴越春秋·句践入臣外传》:“时过于期,否终则泰。” 唐·白居易《遣怀诗》:“乐往必悲生,泰来犹否极。” 唐·韦庄《湘中作》:“否去泰来终可待。”

【英文】

after a storm comes a calm

【反义词】

乐极生悲 after joy comes sadness

此模块包含一此能以二进制格式来读写 Python 值的函数。 这种格式是 Python 专属的,但是独立于特定的机器架构(即你可以在一台 PC 上写入某个 Python 值,将文件传到一台 Sun 上并在那里读取它)。 这种格式的细节有意不带文档说明;它可能在不同 Python 版本中发生改变(但这种情况极少发生)。 1

这不是一个通用的“持久化”模块。 对于通用的持久化以及通过 RPC 调用传递 Python 对象,请参阅 pickle shelve 等模块。 marshal 模块主要是为了支持读写 .pyc 文件形式“伪编译”代码的 Python 模块。 因此,Python 维护者保留在必要时以不向下兼容的方式修改 marshal 格式的权利。 如果你要序列化和反序列化 Python 对象,请改用 pickle 模块 – 其执行效率相当,版本独立性有保证,并且 pickle 还支持比 marshal 更多样的对象类型。

警告

marshal 模块对于错误或恶意构建的数据来说是不安全的。 永远不要 unmarshal 来自不受信任的或未经验证的来源的数据。

不是所有 Python 对象类型都受支持;一般来说,此模块只能写入和读取不依赖于特定 Python 调用的对象。 下列类型是受支持的:布尔值、整数、浮点数、复数、字符串、字节串、字节数组、元组、列表、集合、冻结集合、字典和代码对象,需要了解的一点是元组、列表、集合、冻结集合和字典只在其所包含的值也是这些值时才受支持。 单例对象 None , Ellipsis and StopIteration 也可以被 marshal 和 unmarshal。 对于 version 低于 3 的格式,递归列表、集合和字典无法被写入(见下文)。

有些函数可以读/写文件,还有些函数可以操作字节类对象。

这个模块定义了以下函数:

  • marshal.dump ( value , file [, version ])

    向打开的文件写入值。 值必须为受支持的类型。 文件必须为可写的 binary file 。如果值具有(或所包含的对象具有)不受支持的类型,则会引发 ValueError — 但是将向文件写入垃圾数据。 对象也将不能正确地通过 load() 重新读取。 version 参数指明 dump 应当使用的数据格式(见下文)。

  • marshal.load ( file )

    从打开的文件读取一个值并返回。 如果读不到有效的值(例如由于数据为不同 Python 版本的不兼容 marshal 格式),则会引发 EOFError , ValueError TypeError 。 文件必须为可读的 binary file 。注解 如果通过 dump() marshal 了一个包含不受支持类型的对象, load() 将为不可 marshal 的类型替换 None

  • marshal.dumps ( value [, version ])

    返回将通过 dump(value, file) 被写入一个文件的字节串对象。 值必须属于受支持的类型。 如果值属于(或包含的对象属于)不受支持的类型则会引发 ValueError version 参数指明 dumps 应当使用的数据类型(见下文)。

  • marshal.loads ( bytes )

    bytes-like object 转换为一个值。 如果找不到有效的值,则会引发 EOFError , ValueError TypeError 。 输入的额外字节串会被忽略。

此外,还定义了以下常量:

  • marshal.version

    指明模块所使用的格式。 第 0 版为历史格式,第 1 版为共享固化的字符串,第 2 版对浮点数使用二进制格式。 第 3 版添加了对于对象实例化和递归的支持。 目前使用的为第 4 版。

例子

import marshal
data1 = ['abc',12,23,'jb51']  #几个测试数据
data2 = {1:'aaa',"b":'dad'}
data3 = (1,2,4)
 
output_file = open("a.txt",'wb')#把这些数据序列化到文件中,注:文件必须以二进制模式打开
marshal.dump(data1,output_file)
marshal.dump(data2,output_file)
marshal.dump(data3,output_file)
output_file.close()
 
 
input_file = open('a.txt','rb')#从文件中读取序列化的数据
#data1 = []
data1 = marshal.load(input_file)
data2 = marshal.load(input_file)
data3 = marshal.load(input_file)
print data1#给同志们打印出结果看看
print data2
print data3
 
 
outstring = marshal.dumps(data1)#marshal.dumps()返回是一个字节串,该字节串用于写入文件
open('out.txt','wb').write(outstring)
 
file_data = open('out.txt','rb').read()
real_data = marshal.loads(file_data)
print(real_data)

About Joyk


Aggregate valuable and interesting links.
Joyk means Joy of geeK