python中pickle模块学习

在python中有一个pickle的标准模块,这个模块可以把几乎python中所有类型通过模块转换成pickle所能识别的格式进行存储。

 pickel模块主要有两个函数dump()和load()

 dump()可以把数据对象以特定的格式保存在指定的文件中

  语法:

   pickle.dump(obj,file)

 load()是从文件中提取已经经过pickle序列化的数据,pickle通过自己的方法进行恢复到原来的格式。

  语法:

    pickle.load(file)


pickle的使用:

   首先使用dump()对一组数据进行序列化存储

 

1
2
3
4
5
6
7
8
9
#!/usr/bin/env python
import  pickle
account_info = {
     82345056  : [ '123' , '150' ],
     82345057  : [ 'avcd' , '90' ]
}
pkl_file = file( 'account.pkl' , 'wb' )     #文件保存在account.pkl中
pickle.dump(account_info, pkl_file)     #通过dump函数进行序列化处理
pkl_file.close()

当执行完个脚本的时候会在当前目录下产生一个account.pkl的文件

 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
root@addam: / script #more account.pkl
(dp0
I82345056
(lp1
S '123'
p2
aS '150'
p3
asI82345057
(lp4
S 'avcd'
p5
aS '90'
p6
as.

这就是经过pickle序列化之后的文件,当然这个格式估计只有pickle才明白是用什么格式弄出来的吧,哈哈。。下面要在新的文件中引用这个文件,我们就需要用load()了:

   

1
2
3
4
5
6
7
#!/usr/bin/env python
import  pickle
pkl_file = file( 'account.pkl' , 'rb' )         #打开刚才存储的文件
account_dic = pickle.load(pkl_file)         #通过load转换回来
print account_dic
pkl_file.close()
~

执行结果如下

1
2
root@addam: / script #python Lod.py
{ 82345056 : [ '123' '150' ],  82345057 : [ 'avcd' '90' ]}


当然在这个过程中如果我们要修改其中的内容怎么办呢,很简单了

 

1
2
3
4
5
6
7
8
9
10
#!/usr/bin/env python
import  pickle
account_info  =  {
     82345056  : [ '123' , '150' ,],
     82345057  : [ 'avcd' , '90' ]
}
pkl_file  =  file ( 'account.pkl' , 'wb' )
account_info[ 82345057 ][ 0 =  'abcd123'      #将82345057中列表的第一个值修改为abcd23
pickle.dump(account_info, pkl_file)
pkl_file.close()

 下面我们重新load一下看看是不是修改了呢?

1
2
root@addam: / script #python Lod.py
{ 82345056 : [ '123' '150' ],  82345057 : [ 'abcd123' '90' ]}

好吧,现在我们可以看到已经修改成功了哦。

 pikcle模块在python中的功能很强大,也是以后经常要用的模块哦。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值