成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Python pickle模塊:實現(xiàn)Python對象的持久化存儲

開發(fā) 后端
Python 中有個序列化過程叫作 pickle,它能夠?qū)崿F(xiàn)任意對象與文本之間的相互轉(zhuǎn)化,也可以實現(xiàn)任意對象與二進制之間的相互轉(zhuǎn)化。

[[440586]]

 Python 中有個序列化過程叫作 pickle,它能夠?qū)崿F(xiàn)任意對象與文本之間的相互轉(zhuǎn)化,也可以實現(xiàn)任意對象與二進制之間的相互轉(zhuǎn)化。也就是說,pickle 可以實現(xiàn) Python 對象的存儲及恢復(fù)。

值得一提的是,pickle 是 python 語言的一個標(biāo)準(zhǔn)模塊,安裝 python 的同時就已經(jīng)安裝了 pickle 庫,因此它不需要再單獨安裝,使用 import 將其導(dǎo)入到程序中,就可以直接使用。

 pickle 模塊提供了以下 4 個函數(shù)供我們使用:

  1.   dumps():將 Python 中的對象序列化成二進制對象,并返回;
  2.   loads():讀取給定的二進制對象數(shù)據(jù),并將其轉(zhuǎn)換為 Python 對象;
  3.   dump():將 Python 中的對象序列化成二進制對象,并寫入文件;
  4.   load():讀取指定的序列化數(shù)據(jù)文件,并返回對象。

以上這 4 個函數(shù)可以分成兩類,其中 dumps 和 loads 實現(xiàn)基于內(nèi)存的 Python 對象與二進制互轉(zhuǎn);dump 和 load 實現(xiàn)基于文件的 Python 對象與二進制互轉(zhuǎn)。

pickle.dumps()函數(shù)

此函數(shù)用于將 Python 對象轉(zhuǎn)為二進制對象,其語法格式如下: 

  1. dumps(obj, protocol=None, *, fix_imports=True

此格式中各個參數(shù)的含義為:

  •  obj:要轉(zhuǎn)換的 Python 對象;
  •  protocol:pickle 的轉(zhuǎn)碼協(xié)議,取值為 0、1、2、3、4,其中 0、1、2 對應(yīng) Python 早期的版本,3 和 4 則對應(yīng) Python 3.x 版本及之后的版本。未指定情況下,默認為 3。
  •  其它參數(shù):為了兼容 Python 2.x 版本而保留的參數(shù),Python 3.x 中可以忽略。

【例 1】 

  1. import pickle  
  2. tup1 = ('I love Python', {1,2,3}, None)  
  3. #使用 dumps() 函數(shù)將 tup1 轉(zhuǎn)成 p1  
  4. p1 = pickle.dumps(tup1)  
  5. print(p1) 

輸出結(jié)果為: 

  1. b'\x80\x03X\r\x00\x00\x00I love Pythonq\x00cbuiltins\nset\nq\x01]q\x02(K\x01K\x02K\x03e\x85q\x03Rq\x04N\x87q\x05.' 

pickle.loads()函數(shù)

此函數(shù)用于將二進制對象轉(zhuǎn)換成 Python 對象,其基本格式如下: 

  1. loads(data, *, fix_imports=Trueencoding='ASCII'errors='strict'

其中,data 參數(shù)表示要轉(zhuǎn)換的二進制對象,其它參數(shù)只是為了兼容 Python 2.x 版本而保留的,可以忽略。

【例 2】在例 1 的基礎(chǔ)上,將 p1 對象反序列化為 Python 對象。 

  1. import pickle  
  2. tup1 = ('I love Python', {1,2,3}, None)  
  3. p1 = pickle.dumps(tup1)  
  4. #使用 loads() 函數(shù)將 p1 轉(zhuǎn)成 Python 對象  
  5. t2 = pickle.loads(p1)  
  6. print(t2) 

運行結(jié)果為: 

  1. ('I love Python', {1, 2, 3}, None) 

注意,在使用 loads() 函數(shù)將二進制對象反序列化成 Python 對象時,會自動識別轉(zhuǎn)碼協(xié)議,所以不需要將轉(zhuǎn)碼協(xié)議當(dāng)作參數(shù)傳入。并且,當(dāng)待轉(zhuǎn)換的二進制對象的字節(jié)數(shù)超過 pickle 的 Python 對象時,多余的字節(jié)將被忽略。

pickle.dump()函數(shù)

此函數(shù)用于將 Python 對象轉(zhuǎn)換成二進制文件,其基本語法格式為: 

  1. dump (obj, file,protocol=None, *, fix mports=True

其中各個參數(shù)的具體含義如下:

  •  obj:要轉(zhuǎn)換的 Python 對象。
  •  file:轉(zhuǎn)換到指定的二進制文件中,要求該文件必須是以"wb"的打開方式進行操作。
  •  protocol:和 dumps() 函數(shù)中 protocol 參數(shù)的含義完全相同,因此這里不再重復(fù)描述。
  •  其他參數(shù):為了兼容以前 Python 2.x版本而保留的參數(shù),可以忽略。

【例 3】將 tup1 元組轉(zhuǎn)換成二進制對象文件。 

  1. import pickle  
  2. tup1 = ('I love Python', {1,2,3}, None)  
  3. #使用 dumps() 函數(shù)將 tup1 轉(zhuǎn)成 p1  
  4. with open ("a.txt", 'wb') as f: #打開文件  
  5.     pickle.dump(tup1, f) #用 dump 函數(shù)將 Python 對象轉(zhuǎn)成二進制對象文件 

運行完此程序后,會在該程序文件同級目錄中,生成 a.txt 文件,但由于其內(nèi)容為二進制數(shù)據(jù),因此直接打開會看到亂碼。

pickle.load()函數(shù)

此函數(shù)和 dump() 函數(shù)相對應(yīng),用于將二進制對象文件轉(zhuǎn)換成 Python 對象。該函數(shù)的基本語法格式為: 

  1. load(file, *, fix_imports=Trueencoding='ASCII'errors='strict'

其中,file 參數(shù)表示要轉(zhuǎn)換的二進制對象文件(必須以 "rb" 的打開方式操作文件),其它參數(shù)只是為了兼容 Python 2.x 版本而保留的參數(shù),可以忽略。

【例 4】將例 3 轉(zhuǎn)換的 a.txt 二進制文件對象轉(zhuǎn)換為 Python 對象。 

  1. import pickle  
  2. tup1 = ('I love Python', {1,2,3}, None)  
  3. #使用 dumps() 函數(shù)將 tup1 轉(zhuǎn)成 p1  
  4. with open ("a.txt", 'wb') as f: #打開文件  
  5.     pickle.dump(tup1, f) #用 dump 函數(shù)將 Python 對象轉(zhuǎn)成二進制對象文件  
  6. with open ("a.txt", 'rb') as f: #打開文件  
  7.     t3 = pickle.load(f) #將二進制文件對象轉(zhuǎn)換成 Python 對象  
  8.     print(t3) 

運行結(jié)果為: 

  1. ('I love Python', {1, 2, 3}, None) 

總結(jié)

看似強大的 pickle 模塊,其實也有它的短板,即 pickle 不支持并發(fā)地訪問持久性對象,在復(fù)雜的系統(tǒng)環(huán)境下,尤其是讀取海量數(shù)據(jù)時,使用 pickle 會使整個系統(tǒng)的I/O讀取性能成為瓶頸。這種情況下,可以使用 ZODB。

ZODB 是一個健壯的、多用戶的和面向?qū)ο蟮臄?shù)據(jù)庫系統(tǒng),專門用于存儲 Python 語言中的對象數(shù)據(jù),它能夠存儲和管理任意復(fù)雜的 Python 對象,并支持事務(wù)操作和并發(fā)控制。并且,ZODB 也是在 Python 的序列化操作基礎(chǔ)之上實現(xiàn)的,因此要想有效地使用 ZODB,必須先學(xué)好 pickle。 

 

責(zé)任編輯:龐桂玉 來源: 馬哥Linux運維
相關(guān)推薦

2023-12-14 07:30:04

PicklePython模塊

2009-09-29 16:11:45

Hibernate實現(xiàn)

2016-10-20 15:54:08

Python數(shù)據(jù)序列化

2021-09-11 10:41:27

PythonPickle模塊

2023-08-29 07:34:43

Mimir微服務(wù)

2022-11-29 08:05:48

KubernetesPVCSI

2017-09-21 08:16:33

數(shù)據(jù)存儲環(huán)境

2009-09-24 15:42:44

Hibernate對象

2010-03-03 16:36:02

Python PAMI

2024-03-15 08:18:05

Shelve模塊Python工具

2022-09-21 10:50:43

pickledillPython

2023-12-29 08:19:52

應(yīng)用程序開發(fā)者數(shù)據(jù)庫

2022-08-22 07:58:14

容器云存儲開發(fā)

2021-05-25 10:20:31

Python持久性編程語言

2009-09-23 17:00:07

Hibernate持久

2010-08-11 08:44:01

Flex對象

2022-07-06 14:16:19

Python數(shù)據(jù)函數(shù)

2020-09-30 10:10:52

攻擊

2023-11-15 09:32:19

消息實踐

2023-11-26 09:06:46

點贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 国产精品入口 | 国产一区二区 | 久久国产成人 | 成人av观看 | 日韩欧美专区 | 欧美成人第一页 | 一级黄色毛片子 | 国产专区视频 | 盗摄精品av一区二区三区 | 精品一区二区三区入口 | 精品一区二区三区不卡 | 欧美精品久久 | 日韩成人影院在线观看 | 欧美黄色片在线观看 | 久久国产区 | 日本一道本视频 | 在线观看免费国产 | 国产在线一区二区三区 | 久久精品欧美电影 | 国产高潮好爽受不了了夜色 | 国产免费一区二区三区 | 农夫在线精品视频免费观看 | 色婷婷综合网 | 在线成人www免费观看视频 | 久久99精品久久久久婷婷 | 中文字幕一区二区三区在线视频 | 涩涩视频网站在线观看 | 三级在线视频 | 欧美偷偷 | 久久久123| 国产三区视频在线观看 | 古装三级在线播放 | 波多野结衣一二三区 | 亚洲欧美自拍偷拍视频 | 一个色在线| 亚洲视频免费 | 91天堂网 | 久操伊人 | 久久免费精品视频 | 香蕉久久a毛片 | www.久久久.com |