欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

用pickle存儲(chǔ)Python的原生對(duì)象方法

 更新時(shí)間:2017年04月28日 08:40:20   投稿:jingxian  
下面小編就為大家?guī)?lái)一篇用pickle存儲(chǔ)Python的原生對(duì)象方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧

在Python中存儲(chǔ)數(shù)據(jù)到文件中時(shí),簡(jiǎn)單的做法是調(diào)用open函數(shù)執(zhí)行文件寫入操作,但是這樣做的話,當(dāng)我們要重新讀取文件內(nèi)容時(shí),就會(huì)出現(xiàn)類型不匹配的情況,因?yàn)樽x取的都是字符串的形式,所以還需要進(jìn)行類型轉(zhuǎn)換,這樣不簡(jiǎn)潔。

或者使用eval函數(shù)把字符串轉(zhuǎn)換為對(duì)象,但是有時(shí)它過(guò)于強(qiáng)大,它會(huì)執(zhí)行Python的任何表達(dá)式,甚至做出威脅系統(tǒng)正常工作的表達(dá)式,這樣做不安全。

如果想存儲(chǔ)Python原生對(duì)象,但又無(wú)法信賴文件的數(shù)據(jù)來(lái)源,那么pickle模塊會(huì)是個(gè)理想的選擇。

pickle模塊是能夠讓我們直接在文件中存儲(chǔ)幾乎任何Python對(duì)象的高級(jí)工具,并不要求我們把字符串轉(zhuǎn)換來(lái)轉(zhuǎn)換去,像是個(gè)超級(jí)通用的數(shù)據(jù)格式化和解析工具。

demo.py:

D = {'name':'Allen', 'age':21}
f = open('p_data.pkl','wb')
import pickle
pickle.dump(D,f)
f.close()

f=open('p_data.pkl','rb')
e=pickle.load(f)
print(e)
print(type(e))

控制臺(tái)輸出:

{'name': 'Allen', 'age': 21}
<class 'dict'>
[Finished in 0.4s]

然后它會(huì)在指定路徑下生成p_data.pkl文件:

8003 7d71 0028 5804 0000 006e 616d 6571
0158 0500 0000 416c 6c65 6e71 0258 0300
0000 6167 6571 034b 1575 2e

如果控制臺(tái)提示”attributeError:'module' object has no attribute ‘dump'”,那么很可能是因?yàn)槟愕奈募麨椤眕ickle.py”,這與內(nèi)置模塊文件重名了,改一下就可以了。。

以上這篇用pickle存儲(chǔ)Python的原生對(duì)象方法就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

最新評(píng)論