利用shelve模块,你可以将Python程序中的变量保存到二进制的shelf文件中。 这样,程序就可以从硬盘中恢复变量的数据。shelve模块可以让你在程序中添加“保存” 和“打开”功能。#代码import shelve shelfFile = shelve.open('mydata')cats = ['Zophie', 'Pooka', 'Simon'] shelfFile['cats'] = cats shelfFile.close()
要利用shelve模块读写数据,首先要导入它。调用函数shelve.open()并传入一个文件名,然后将返回的值保存在一个变量中。可以对这个变量的shelf值进行修改,就像它是一个字典一样。当你完成时,在这个值上调用close()。这里,我们的shelf值保存在shelfFile 中。我们创建了一个列表cats,并写下shelfFile['cats'] =cats,将该列表保存在shelfFile 中,作为键'cats'关联的值(就像在字典中一样)。然后我们在shelfFile上调用close()。在Windows上运行前面的代码,你会看到在当前工作目录下有 3 个新文件: mydata.bak、mydata.dat 和 mydata.dir。在OS X 上,只会创建一个 mydata.db 文件。这些二进制文件包含了存储在 shelf 中的数据。这些二进制文件的格式并不重要,你只需要知道shelve模块做了什么,而不必知道它是怎么做的。该模块让你不用操心如何将程序的数据保存到文件中。程序稍后可以使用shelve模块,重新打开这些文件并取出数据。shelf值不 必用读模式或写模式打开,因为它们在打开后,既能读又能写。#代码shelfFile = shelve.open('mydata') print(type(shelfFile))#运行输出结果:<class 'shelve.DbfilenameShelf'>print(shelfFile['cats'])#运行输出结果:['Zophie', 'Pooka', 'Simon']shelfFile.close()
这里,我们打开了shelf文件,检查我们的数据是否正确存储。输入shelfFile['cats'] 将返回我们前面保存的同一个列表,所以我们就知道该列表得到了正确存储,然后调用close()。就像字典一样,shelf值有keys()和values()方法,返回shelf中键和值的类似列表的值。因为这些方法返回类似列表的值,而不是真正的列表,所以应该将它们传递给list()函数,取得列表的形式。#代码shelfFile = shelve.open('mydata')print(list(shelfFile.keys()))#运行输出结果 ['cats']print(list(shelfFile.values()))#运行输出结果 [['Zophie', 'Pooka', 'Simon']] shelfFile.close()
创建文件时,如果你需要在Notepad或TextEdit 这样的文本编辑器中读取它们, 纯文本就非常有用。但是,如果想要保存Python程序中的数据,那就使用shelve模块。更多往期内容在公众号中,你的关注是我持续更新的动力,奥里给!一起加油学习!