python standard library marshal

marshal — 内部 Python 对象序列化

每日一词:

否极泰来( pi ji tai lai):

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

【出典】:

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

【例句】:

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

【英文】

after a storm comes a calm

【反义词】

乐极生悲 after joy comes sadness

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

这不是一个通用的“持久化”模块。 对于通用的持久化以及通过 RPC 调用传递 Python 对象,请参阅 pickleshelve 等模块。 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, ValueErrorTypeError。 文件必须为可读的 binary file。注解 如果通过 dump() marshal 了一个包含不受支持类型的对象,load() 将为不可 marshal 的类型替换 None

  • marshal.dumps(value[, version])

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

  • marshal.loads(bytes)

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

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

  • marshal.version

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

例子

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
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)
坚持原创技术分享,您的支持将鼓励我继续创作!
0%