序列化pickle与cPickle

序列化 (Serialization)是将对象的状态信息转换为可以存储或传输的形式的过程。在序列化期间,对象将其当前状态写入到临时或持久性存储区。以后,可以通过从存储区中读取或反序列化对象的状态,重新创建该对象。
通俗理解序列化就是将数据保存到文件中,反序列化就是将数据读取到内存中.保存到json,xml等文件中都是序列化.常见的还有利用pickle,cPickle等
pickle是python自带模块,能保存较为复杂的数据,如类,以及网络参数等,这是json不擅长的.cPickle则是由c编译的,用法与pickle几乎一样,速度更快(据说快1000倍).
# import pickle
# import cPickle as pickle  #利用这个,代码都不用换了

pickle模块提供了四个功能:dumps、dump、loads、load。
dumps,dump:进行序列化
	dumps将所传入的变量的值序列化为一个bytes,然后,就可以将这个bytes写入磁盘或者进行传输。
	而dump则更加一步到位,在dump中可以传入两个参数,一个为需要序列化的变量,另一个为需要写入的文件。
loads,load:反序列化,区别同上

import pickle
d=[1,2,3,4]
pickle.dumps(d)
# b'\x80\x03]q\x00(K\x01K\x02K\x03K\x04e.'

f=open('file_test','wb')
d=[1,2,3,4]
pickle.dump(d,f)
f.close()
f=opem('file_test','rb')
f=open('file_test','rb')
	f.read()
# b'\x80\x03]q\x00(K\x01K\x02K\x03K\x04e.'

loads当我们要把对象从磁盘读到内存时,可以先把内容读到一个bytes,然后用loads方法反序列化出对象,也可以直接用load方法直接反序列化一个文件

d=[1,2,3,4]
r=pickle.dumps(d)
print(r)
# b'\x80\x03]q\x00(K\x01K\x02K\x03K\x04e.'
pickle.loads(r)
# [1, 2, 3, 4]

d=[1,2,3,4]
f=open('file_test','wb')
pickle.dump(d,f)
f.close()
f=open('file_test','rb')
r=pickle.load(f)
f.close()
print(r)
# [1, 2, 3, 4]

转载于:https://my.oschina.net/u/3726752/blog/3089802

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值