亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

老生常談Python中的Pickle庫(kù)

 更新時(shí)間:2022年01月23日 11:47:21   作者:A-L-Kun  
pickle是python語(yǔ)言的一個(gè)標(biāo)準(zhǔn)模塊,安裝python后已包含pickle庫(kù),不需要單獨(dú)再安裝。這篇文章主要介紹了Python中的Pickle庫(kù),需要的朋友可以參考下

簡(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ì)象,并寫入文件
  • 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)

到此這篇關(guān)于Python中的Pickle庫(kù)的文章就介紹到這了,更多相關(guān)Python Pickle庫(kù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評(píng)論