序列化过程将文本信息转变为二进制数据流。这样就信息就容易存储在硬盘之中,当需要读取文件的时候,从硬盘中读取数据,然后再将其反序列化便可以得到原始的数据。在Python程序运行中得到了一些字符串、列表、字典等数据,想要长久的保存下来,方便以后使用,而不是简单的放入内存中关机断电就丢失数据。python模块大全中的Pickle模块就派上用场了,它可以将对象转换为一种可以传输或存储的格式。
loads()函数执行和load() 函数一样的反序列化。取代接受一个流对象并去文件读取序列化后的数据,它接受包含序列化后的数据的str对象, 直接返回的对象。
模块使用
#!/usr/bin/env python
#-*- coding=utf-8 -*-
import pickle
obj = 123, "abcdedf", ["ac", 123], {"key": "value", "key1": "value1"}
print obj
with open("a", "w") as f:
pickle.dump(obj, f) ##写入
with open("a") as f:
print pickle.load(f) ##输出
文件输出
(I123
S'abcdedf'
p0
(lp1
S'ac'
p2
aI123
a(dp3
S'key1'
p4
S'value1'
p5
sS'key'
p6
S'value'
p7
stp8
.
output输出
C:\Python27\python.exe C:/Users/acer-pc/Desktop/test_delete/api_cqproject/zgd/test.py
(123, 'abcdedf', ['ac', 123], {'key1': 'value1', 'key': 'value'})
(123, 'abcdedf', ['ac', 123], {'key1': 'value1', 'key': 'value'})
Process finished with exit code 0
pickle.dumps()
方法的参数如下:
pickle.dumps(obj, protocol=None,*,fix_imports=True)
pickle.dumps()
方法跟
pickle.dump()
方法的区别在于,
pickle.dumps()
方法不需要写入文件中,它是直接返回一个序列化的bytes对象。
参考链接:http://www.php.cn/python-tutorials-372984.html