pickle序列化

序列化的使用场景:

1)进程A创建了对象,需要分发给另一个进程B,让B协助完成工作。 A就需要把对象序列化成文件,然后B可以读取。 注意:pickle不安全,不能用于网络通信。

2)状态保存。将中间结果序列化,以后可以直接使用,不用每次都重新计算生成,即Save/Load。

 

通过pickle来序列化:

# -*- coding: utf-8 -*-
import pickle
#-------------------序列化---------------------
zoo_animals_1 = {
'Unicorn' : 'Cotton Candy House',
'Sloth' : 'Rainforest Exhibit',
'Bengal Tiger' : 'Jungle House',
'Atlantic Puffin' : 'Arctic Exhibit',
'Rockhopper Penguin' : 'Arctic Exhibit'}

zoo_animals_2 = {
'Unicorn 2' : 'Cotton Candy House',
'Sloth 2' : 'Rainforest Exhibit',
'Bengal Tiger 2' : 'Jungle House',
'Atlantic Puffin 2' : 'Arctic Exhibit',
'Rockhopper Penguin 2' : 'Arctic Exhibit'}

#序列化。如果有多个数据要序列化,可以汇总到一个字典里。
all_data = {'zoo1':zoo_animals_1, 'zoo2':zoo_animals_2}

pickle_file = open('list.pkl', 'wb')

pickle.dump(all_data, pickle_file, 0)
#pickle.dump(zoo_animals, administrator, 0)

pickle_file.close()

#-------------------反序列化---------------------
pickle_file = open('list.pkl', 'rb')

all_data = pickle.load(pickle_file)

pickle_file.close()

print all_data
print '---------------'
zoo_animals_3 = all_data['zoo1']
print zoo_animals_3['Unicorn']

 

转载于:https://www.cnblogs.com/ruanchao/p/5878754.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值