学习了文件和文件系统,知道从一个文件里面去读取字符串是非常简单,但是读取出数值的话就很麻烦,因为无论read()方法 还是 readline()方法,都是返回一个字符串。
如果希望从字符串中取出数值的话,使用int() 或 float()函数,把类似于1,2,3或者3.14的字符串强制转换为整型或者浮点型数值。
对于保存文件,当要保存的数据像列表,字典,集合甚至是类的实例这些更加复杂的数据类型的时候,没有什么好办法。可以把这些都转化为字符串,然后再写入到一个文本文件中保存起来。但是从文本文件中恢复数据对象,即把一个字符串恢复成列表,字典,集合,类的实例的时候,异常的困难。
所幸的是,Python提供了一个标准的模块(pickle)使用这个模块,我们就可以轻松地将列表,字典,集合,类的实例这类复杂的类型转换为二进制文件了。pickle模块
就是泡菜、腌菜的意思,它几乎可以把所有Python的对象转换为二进制的形式存放,这个过程我们称之为 pickling(存放),从二进制的形式转换为对象的过程我们叫做 unpickling(读取),举例说明:
>>> import pickle >>> my_list = [521, 6.01, '钏钏', ['r4n']] >>> pickle_file = open('my_list.pkl', 'wb') #这里使用的pkl后缀名只是为了方便记忆,一定要‘wb’的形式,可写+二进制 >>> pickle.dump(my_list, pickle_file) #使用dump()方法写入 >>> pickle_file.close() #关闭文件,我们会在文件夹看到my_list.pkl这个文件
>>> pickle_file = open('my_list.pkl', 'rb') #对该文件进行读取,一定要用‘rb’的形式,二进制读取 >>> my_list2 = pickle.load(pickle_file) ##使用load()方法读取 >>> my_list2 [521, 6.01, '钏钏', ['r4n']]