python中pickle模块学习

   在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中的功能很强大,也是以后经常要用的模块哦。