发布时间:2019-09-07 08:12:42编辑:auto阅读(1926)
在python中有一个pickle的标准模块,这个模块可以把几乎python中所有类型通过模块转换成pickle所能识别的格式进行存储。
pickel模块主要有两个函数dump()和load()
dump()可以把数据对象以特定的格式保存在指定的文件中
语法:
pickle.dump(obj,file)
load()是从文件中提取已经经过pickle序列化的数据,pickle通过自己的方法进行恢复到原来的格式。
语法:
pickle.load(file)
pickle的使用:
首先使用dump()对一组数据进行序列化存储
#!/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的文件
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()了:
#!/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()
~执行结果如下
root@addam:/script#python Lod.py
{82345056: ['123', '150'], 82345057: ['avcd', '90']}当然在这个过程中如果我们要修改其中的内容怎么办呢,很简单了
#!/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一下看看是不是修改了呢?
root@addam:/script#python Lod.py
{82345056: ['123', '150'], 82345057: ['abcd123', '90']}好吧,现在我们可以看到已经修改成功了哦。
pikcle模块在python中的功能很强大,也是以后经常要用的模块哦。
上一篇: python 下chmod方法简单介绍
下一篇: python2.7.10安装配置
51283
50733
41333
38144
32609
29511
28364
23232
23198
21525
1597°
2327°
1928°
1868°
2199°
1911°
2600°
4366°
4213°
2991°