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里定义的类,他们的对象就可以跨机器进行传输和使用

你可能感兴趣的:(python)