網(wǎng)站首頁(yè) 編程語(yǔ)言 正文
簡(jiǎn)介
Python 中有個(gè)序列化過(guò)程叫作 pickle,它能夠?qū)崿F(xiàn)任意對(duì)象與文本之間的相互轉(zhuǎn)化,也可以實(shí)現(xiàn)任意對(duì)象與二進(jìn)制之間的相互轉(zhuǎn)化。也就是說(shuō),pickle 可以實(shí)現(xiàn) Python 對(duì)象的存儲(chǔ)及恢復(fù)。
pickle與json比較
? ? ? ? pickle協(xié)議和JSON ?(JavaScript對(duì)象表示法)之間有基本的區(qū)別:
? ? ? ? JSON是一種文本序列化格式(它輸出unicode文本,盡管大多數(shù)時(shí)候它被編碼為utf-8),而pickle是二進(jìn)制序列化格式;
? ? ? ? JSON是人類可讀的,而pickle則不是;
? ? ? ? JSON在Python生態(tài)系統(tǒng)之外是可互操作和廣泛使用的,而pickle是特定于Python的;
? ? ? ? 默認(rèn)情況下,JSON只能表示Python內(nèi)置類型的一個(gè)子集,并且沒(méi)有自定義類;pickle可以表示極其大量的Python類型(其中許多是自動(dòng)的,通過(guò)聰明地使用Python的內(nèi)省設(shè)施,復(fù)雜的情況可以通過(guò)實(shí)現(xiàn)特定的對(duì)象api來(lái)解決)。
pickle模塊的應(yīng)用很簡(jiǎn)單,只有四個(gè)方法
- dumps():將 Python 中的對(duì)象序列化成二進(jìn)制對(duì)象,并返回
- loads():讀取給定的二進(jìn)制對(duì)象數(shù)據(jù),并將其轉(zhuǎn)換為 Python 對(duì)象
- dump():將 Python 中的對(duì)象序列化成二進(jìn)制對(duì)象,并寫(xiě)入文件
- load():讀取指定的序列化數(shù)據(jù)文件,并返回對(duì)象
其中 dumps 和 loads 實(shí)現(xiàn)基于內(nèi)存的 Python 對(duì)象與二進(jìn)制互轉(zhuǎn);dump 和 load 實(shí)現(xiàn)基于文件的 Python 對(duì)象與二進(jìn)制互轉(zhuǎn)
函數(shù)
dumps
dumps(obj, protocol=None)
- obj:要轉(zhuǎn)換的 Python 對(duì)象
- protocol:pickle 的轉(zhuǎn)碼協(xié)議,取值為 0、1、2、3、4,其中 0、1、2 對(duì)應(yīng) Python 早期的版本,3 和 4 則對(duì)應(yīng) Python 3.x 版本及之后的版本。未指定情況下,默認(rèn)為 3
import pickle dic = {"name": "lihua", "age": 30} pe = pickle.dumps(dic) # 將任意數(shù)據(jù)類型類型轉(zhuǎn)換成二進(jìn)制文件 print(pe)
loads
loads(data)
data 參數(shù)表示要轉(zhuǎn)換的二進(jìn)制對(duì)象
import pickle dic = {"name": "lihua", "age": 30} pe = pickle.dumps(dic) # 將任意數(shù)據(jù)類型轉(zhuǎn)換成二進(jìn)制文件 dic1 = pickle.loads(pe) # 將二進(jìn)制文件恢復(fù)成原來(lái)的數(shù)據(jù)類型 print(dic1)
dump
dump (obj, file,protocol=None)
- obj:要轉(zhuǎn)換的 Python 對(duì)象
- file:轉(zhuǎn)換到指定的二進(jìn)制文件中,要求該文件必須是以"wb"的打開(kāi)方式進(jìn)行操作
- protocol:pickle 的轉(zhuǎn)碼協(xié)議,取值為 0、1、2、3、4,其中 0、1、2 對(duì)應(yīng) Python 早期的版本,3 和 4 則對(duì)應(yīng) Python 3.x 版本及之后的版本。未指定情況下,默認(rèn)為 3
import pickle dic = {"name": "lihua", "age": 30} with open("pickle.pickle", "wb") as f: pickle.dump(dic, f) # 將轉(zhuǎn)換后的二進(jìn)制文件存儲(chǔ)在pickle.pickle文件里面
load
此函數(shù)和 dump() 函數(shù)相對(duì)應(yīng),用于將二進(jìn)制對(duì)象文件轉(zhuǎn)換成 Python 對(duì)象
load(file)
file 參數(shù)表示要轉(zhuǎn)換的二進(jìn)制對(duì)象文件(必須以 "rb" 的打開(kāi)方式操作文件)
import pickle dic = {"name": "lihua", "age": 30} with open("pickle.pickle", "rb") as f: dic1 = pickle.load(f) # 將存儲(chǔ)的文件內(nèi)容導(dǎo)出為python對(duì)象 print(dic1)
原文鏈接:https://www.cnblogs.com/liuzhongkun/p/15831477.html
相關(guān)推薦
- 2022-04-25 C#實(shí)戰(zhàn)之備忘錄的制作詳解_C#教程
- 2022-05-12 HarmonyOS 單擊 雙擊 長(zhǎng)按 滑動(dòng)事件
- 2023-05-31 python常用函數(shù)random()函數(shù)詳解_python
- 2022-04-06 詳解pandas中缺失數(shù)據(jù)處理的函數(shù)_python
- 2022-05-09 sql語(yǔ)句中union的用法與踩坑記錄_MsSql
- 2023-11-26 XMLHttpRequest對(duì)象的Get請(qǐng)求和Post請(qǐng)求的用法
- 2023-02-10 Jupyter導(dǎo)入自定義模塊及導(dǎo)入后TypeError錯(cuò)誤問(wèn)題及解決_python
- 2023-03-27 python,pycharm的環(huán)境變量設(shè)置方式_python
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲(chǔ)小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過(guò)濾器
- Spring Security概述快速入門(mén)
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯(cuò)誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡(jiǎn)單動(dòng)態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對(duì)象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支