python中pickle的应用

        从一个文件中读取字符串很简单,但是如果想要读取出数值,那就需要多费些周折。因为无论是read()方法还是readline()方法,都是返回一个字符串,再使用int()或者float()方法强制把字符串转换为具体的数值。那么如果要储存的数据像列表或者字典甚至是类的实例这些复杂的数据类型时,那么从文本文件恢复数据对象,就变得异常麻烦了。
        此时则需要 python 提供的一个标准模块 — pickle模块。pickle英文释义为 “泡菜” ,他几乎可以把所有Python的对象都转化为二进制的形式存放,找个过程称为 pickling,从二进制形式转换回对象的过程称为 unpickling。

一,将python对象转换为pickle二进制文件

import pickle 

my_list = [12,"你好",34,56,78.0,9,["深圳",0,3.14159],10]

pickle_file = open("./pickle_test.pkl","wb")
pickle.dump(my_list, pickle_file)
pickle_file.close()
  • 这里希望把这个列表永久保存起来(保存成文件),打开的文件一定要以二进制的形式打开。
  • 后缀名倒是可以随意,不过既然是使用pickle保存,为了方便记忆,建议使用.pkl或.pickle。
  • 保存后用记事本打开是乱码,因为保存的是二进制形式。

二,将pickle二进制文件转换为python对象

import pickle 

pickle_file = open("./pickle_test.pkl","rb")
my_list = pickle.load(pickle_file)
print(my_list,len(my_list),type(my_list))
  • 在使用的时候只需要二进制模式先把文件打开,然后用load把数据加载进来

总结:利用pickle模块,不仅可以保存列表,事实上 pickle可以保存任何你能想象得到的东西。

猜你喜欢

转载自blog.csdn.net/TFATS/article/details/107838689