Python序列化的概念很簡單。內(nèi)存里面有一個(gè)數(shù)據(jù)結(jié)構(gòu),你希望將它保存下來,重用,或者發(fā)送給其他人。你會怎么做?這取決于你想要怎么保存,怎么重用,發(fā)送給誰。很多游戲允許你在退出的時(shí)候保存進(jìn)度,然后你再次啟動的時(shí)候回到上次退出的地方。(實(shí)際上,很多非游戲程序也會這么干)在這種情況下,一個(gè)捕獲了當(dāng)前進(jìn)度的數(shù)據(jù)結(jié)構(gòu)需要在你退出的時(shí)候保存到硬盤上,接著在你重新啟動的時(shí)候從硬盤上加載進(jìn)來。
Python標(biāo)準(zhǔn)庫提供pickle和cPickle模塊。cPickle是用C編碼的,在運(yùn)行效率上比pickle要高,但是cPickle模塊中定義的類型不能被繼承(其實(shí)大多數(shù)時(shí)候,我們不需要從這些類型中繼承,推薦使用cPickle)。cPickle和pickle的序列化/反序列化規(guī)則是一樣的,使用pickle序列化一個(gè)對象,可以使用cPickle來反序列化。同時(shí),這兩個(gè)模塊在處理自引用類型時(shí)會變得更加“聰明”,它不會無限制的遞歸序列化自引用對象,對于同一對象的多次引用,它只會序列化一次。
pickle模塊中的兩個(gè)主要函數(shù)是dump()和load()。dump()函數(shù)接受一個(gè)數(shù)據(jù)對象和一個(gè)文件句柄作為參數(shù),把數(shù)據(jù)對象以特定的格式保存到給定的文件中。當(dāng)我們使用load()函數(shù)從文件中取出已保存的對象時(shí),pickle知道如何恢復(fù)這些對象到它們本來的格式。
dumps()函數(shù)執(zhí)行和dump()函數(shù)相同的序列化。取代接受流對象并將序列化后的數(shù)據(jù)保存到磁盤文件,這個(gè)函數(shù)簡單的返回序列化的數(shù)據(jù)。
loads()函數(shù)執(zhí)行和load()函數(shù)一樣的反序列化。取代接受一個(gè)流對象并去文件讀取序列化后的數(shù)據(jù),它接受包含序列化后的數(shù)據(jù)的str對象, 直接返回的對象。
cPickle.dump(obj, file, protocol=0)
序列化對象,并將結(jié)果數(shù)據(jù)流寫入到文件對象中。參數(shù)protocol是序列化模式,默認(rèn)值為0,表示以文本的形式序列化。protocol的值還可以是1或2,表示以二進(jìn)制的形式序列化。
cPickle.load(file)
反序列化對象。將文件中的數(shù)據(jù)解析為一個(gè)Python對象。
下面通過一個(gè)簡單的例子來演示上面兩個(gè)方法的使用:
>>> import pickle,cPickle>>> info_dict = {'name':'yeho','age':100,'Lang':'Python'}>>> f = open('info.pkl','wb')>>> pickle.dump(info_dict,f)>>> f.close()>>> exit()
# cat info.pkl(dp0S'Lang'p1S'Python'p2sS'age'p3I100sS'name'p4S'yeho'p5s.
>>> import cPickle>>> info_dictTraceback (most recent call last): File "<stdin>", line 1, in <module>NameError: name 'info_dict' is not defined>>> f = open('info.pkl','r+')>>> info2_dict = cPickle.load(f)>>> info2_dict{'Lang': 'Python', 'age': 100, 'name': 'yeho'}>>> info2_dict['age'] = 110>>> cPickle.dump(info2_dict,f)>>> f.close()>>> exit()
|
新聞熱點(diǎn)
疑難解答
圖片精選