Python標(biāo)準(zhǔn)庫pickle的簡(jiǎn)單使用
1. pickle標(biāo)準(zhǔn)庫簡(jiǎn)介
- pickle,作為名詞表示泡菜,作為動(dòng)詞表示用醋或鹽水保存食物。由此不難聯(lián)想到,用存儲(chǔ)設(shè)備持久化保存數(shù)據(jù)。而pickle標(biāo)準(zhǔn)庫恰是一個(gè) Python 對(duì)象結(jié)構(gòu)的二進(jìn)制序列化和反序列化的核心庫,專用于表示Python語言大量數(shù)據(jù)類型,是序列化 Python 對(duì)象時(shí)的首選。
- pickle標(biāo)準(zhǔn)庫是一個(gè)純Python實(shí)現(xiàn)的標(biāo)準(zhǔn)版本,cPickle標(biāo)準(zhǔn)庫(Python 3.x更名為_pickle)則是C語言實(shí)現(xiàn)的加速版本,讀寫效率較高。
- 實(shí)際使用Python3.x過程中,我們直接導(dǎo)入標(biāo)準(zhǔn)版本即可,源代碼最后部分會(huì)嘗試導(dǎo)入加速版本對(duì)應(yīng)函數(shù),不必單獨(dú)導(dǎo)入pickle模塊,如下所示:
# Use the faster _pickle if possible try: from _pickle import ( PickleError, PicklingError, UnpicklingError, Pickler, Unpickler, dump, dumps, load, loads ) except ImportError: Pickler, Unpickler = _Pickler, _Unpickler dump, dumps, load, loads = _dump, _dumps, _load, _loads
1.1 預(yù)備知識(shí)
- 數(shù)據(jù)持久化(Data Persistence):將內(nèi)存中的數(shù)據(jù)模型轉(zhuǎn)換為存儲(chǔ)模型,以及將存儲(chǔ)模型轉(zhuǎn)換為內(nèi)存中的數(shù)據(jù)模型的統(tǒng)稱,一般是指把瞬時(shí)數(shù)據(jù)(如內(nèi)存中的對(duì)象)轉(zhuǎn)換為持久數(shù)據(jù)永久保存到存儲(chǔ)設(shè)備中(如磁盤)。
- 序列化\反序列化分類:二進(jìn)制序列、文本序列
- 序列化(Serialization):將對(duì)象的狀態(tài)信息轉(zhuǎn)換為可以存儲(chǔ)或傳輸?shù)男问降倪^程,目的是使內(nèi)存中的狀態(tài)信息持久化便于以后恢復(fù)、
- 方便在網(wǎng)絡(luò)傳輸以實(shí)現(xiàn)跨平臺(tái)數(shù)據(jù)交互。
- 反序列化(Deserialization):將序列重新恢復(fù)成對(duì)象的過程,是序列化的逆過程
1.2 pickle與json的對(duì)比
比較維度\標(biāo)準(zhǔn)庫 | pickle | json |
---|---|---|
序列化方式 | 二進(jìn)制序列 | 文本序列 |
人類直觀可讀 | 否 | 是 |
跨平臺(tái)、語言、協(xié)議 | 否,Python專用 | 是 |
數(shù)據(jù)類型表示支持 | 可表示大量Python數(shù)據(jù)類型 | 只能表示Python內(nèi)置類型子集,不能表示自定義的類 |
2. pickle常用函數(shù)
2.1 pickle.dump(obj, file, protocol=None, *, fix_imports=True)
將 Python 對(duì)象寫入已打開的二進(jìn)制文件
# define a dict object obj={ "name":"Bonnie", "isAGirl":True, "age":22, "hobbies":["guitar","singing","traveling"] } # 將obj寫入已打開的二進(jìn)制文件,序列化 with open("puppy_love.pkl","wb") as f: pickle.dump(obj,f,protocol=pickle.HIGHEST_PROTOCOL) # 設(shè)置為可用的最高協(xié)議
2.2 pickle.load(file, *, fix_imports=True, encoding='ASCII', errors='strict')
從已打開的二進(jìn)制文件中讀取打包后的對(duì)象,重建其中特定對(duì)象的層次結(jié)構(gòu)并返回
# 從打開的二進(jìn)制文件重建對(duì)象,反序列化 with open("puppy_love.pkl","rb") as f: obj_again=pickle.load(f) print("反序列化后的對(duì)象為{}".format(obj_again))
2.3 pickle.dumps(obj, protocol=None, *, fix_imports=True)
將 obj 打包以后的對(duì)象作為bytes 類型直接返回,而不是將其寫入到文件
# 將Python對(duì)象直接轉(zhuǎn)為bytes類型,不寫入文件 bytes_obj=pickle.dumps(obj,protocol=pickle.HIGHEST_PROTOCOL) # 設(shè)置為可用的最高協(xié)議 print("obj轉(zhuǎn)換為bytes類型后為{}".format(bytes_obj))
2.4 pickle.loads(data, *, fix_imports=True, encoding='ASCII', errors='strict')
重建并返回一個(gè)對(duì)象的封存表示形式 data 的對(duì)象層級(jí)結(jié)構(gòu),bytes類型將反序列化為Python對(duì)象
# bytes類型將反序列化為Python對(duì)象 obj_origin=pickle.loads(bytes_obj) print("bytes類型將反序列化為obj后{}".format(obj_origin))
3.參考文獻(xiàn)
pickle —— Python 對(duì)象序列化 — Python 3.7.13 文檔
到此這篇關(guān)于Python標(biāo)準(zhǔn)庫pickle的簡(jiǎn)單使用的文章就介紹到這了,更多相關(guān)Python pickle內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python中用函數(shù)作為返回值和實(shí)現(xiàn)閉包的教程
這篇文章主要介紹了Python中用函數(shù)作為返回值和實(shí)現(xiàn)閉包的教程,代碼基于Python2.x版本,需要的朋友可以參考下2015-04-04Python實(shí)現(xiàn)控制臺(tái)輸入密碼的方法
這篇文章主要介紹了Python實(shí)現(xiàn)控制臺(tái)輸入密碼的方法,實(shí)例對(duì)比分析了幾種輸入密碼的方法,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-05-05解決Python pip 自動(dòng)更新升級(jí)失敗的問題
今天小編就為大家分享一篇解決Python pip 自動(dòng)更新升級(jí)失敗的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-02-02構(gòu)建Python中的分布式系統(tǒng)結(jié)合Celery與RabbitMQ
在本文中,我們深入探討了如何利用Celery和RabbitMQ構(gòu)建Python中的分布式系統(tǒng),我們首先介紹了Celery和RabbitMQ的概念及其優(yōu)勢(shì),然后展示了如何結(jié)合它們來創(chuàng)建一個(gè)簡(jiǎn)單但功能強(qiáng)大的分布式系統(tǒng),感興趣的朋友跟隨小編一起看看吧2024-05-0510個(gè)有用的Python字符串函數(shù)小結(jié)
本文主要介紹了10個(gè)有用的Python字符串函數(shù)小結(jié),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-08-08Python pyautogui模塊實(shí)現(xiàn)鼠標(biāo)鍵盤自動(dòng)化方法詳解
這篇文章主要介紹了Python pyautogui 模塊實(shí)現(xiàn)鼠標(biāo)鍵盤自動(dòng)化方法詳解,需要的朋友可以參考下2020-02-02python構(gòu)建自定義回調(diào)函數(shù)詳解
在工作中,回調(diào)函數(shù)使用的場(chǎng)景是非常多的,下面我們就來通過例子程序來詳細(xì)了解利用了Python的屬性機(jī)制構(gòu)建了一個(gè)自定義回調(diào)函數(shù)的使用2017-06-06