Python:序列化

#对象序列化
import pickle
d={"a":"中国"}
a=pickle.dumps(d,2)#序列化二进制
print a
f=open("data","wb")
f.write(a)
f.close()


#对象反序列化
import pickle
f = open("data","rb")
a=f.read()
d=pickle.loads(a)
print d['a']

中文也需要被视为二进制数据,pickle.dumps(d,2)第2个参数取值范围是(0,1,2) 2是二进制

补充说明:


 

如果我们序列化的是类对象(类实例)结果会如何呢?可以在A机器上实例化一个对象并且也可以正确的序列化并传输,到达B机器后在反序列化的时候会产生一个错误,提示说没有实例化这个对象的那个类,但这个时候定义这个类,那么就可以反序列化成功,并且方法调用也没有问题,这就是说,在序列化的时候,对象的元信息打入进包里,但是这些元信息在B机器上找不到时就产生了错误

结论:A,B机器如果有同一个LIB,那么这个LIB里定义的类,他们的对象就可以跨机器进行传输和使用

转载于:https://www.cnblogs.com/code-style/archive/2012/03/18/2405210.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值