網站首頁 編程語言 正文
前言:
Python 中有個序列化過程叫作 pickle,它能夠實現任意對象與文本之間的相互轉化,也可以實現任意對象與二進制之間的相互轉化。也就是說,pickle 可以實現 Python 對象的存儲及恢復。
值得一提的是,pickle 是 python 語言的一個標準模塊,安裝 python 的同時就已經安裝了 pickle 庫,因此它不需要再單獨安裝,使用 import 將其導入到程序中,就可以直接使用。
pickle 模塊提供了以下 4 個函數供我們使用:
- dumps():將 Python 中的對象序列化成二進制對象,并返回;
- loads():讀取給定的二進制對象數據,并將其轉換為 Python 對象;
- dump():將 Python 中的對象序列化成二進制對象,并寫入文件;
- load():讀取指定的序列化數據文件,并返回對象。
以上這 4 個函數可以分成兩類,其中 dumps
和 loads
實現基于內存的 Python 對象與二進制互轉;dump 和 load 實現基于文件的 Python 對象與二進制互轉。
pickle.dumps()函數
此函數用于將 Python 對象轉為二進制對象,其語法格式如下:
dumps(obj,?protocol=None,?*,?fix_imports=True)
此格式中各個參數的含義為:
- obj:要轉換的 Python 對象;
- protocol:pickle 的轉碼協議,取值為 0、1、2、3、4,其中 0、1、2 對應 Python 早期的版本,3 和 4 則對應 Python 3.x 版本及之后的版本。未指定情況下,默認為 3。
- 其它參數:為了兼容 Python 2.x 版本而保留的參數,Python 3.x 中可以忽略。
【例 1】
import?pickle tup1?=?('I?love?Python',?{1,2,3},?None) #使用?dumps()?函數將?tup1?轉成?p1 p1?=?pickle.dumps(tup1) print(p1)
輸出結果為:
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()函數
此函數用于將二進制對象轉換成 Python 對象,其基本格式如下:
loads(data,?*,?fix_imports=True,?encoding='ASCII',?errors='strict')
其中,data 參數表示要轉換的二進制對象,其它參數只是為了兼容 Python 2.x 版本而保留的,可以忽略。
【例 2】在例 1 的基礎上,將 p1 對象反序列化為 Python 對象。
import?pickle tup1?=?('I?love?Python',?{1,2,3},?None) p1?=?pickle.dumps(tup1) #使用?loads()?函數將?p1?轉成?Python?對象 t2?=?pickle.loads(p1) print(t2)
運行結果為:
('I?love?Python',?{1,?2,?3},?None)
注意:在使用 loads() 函數將二進制對象反序列化成 Python 對象時,會自動識別轉碼協議,所以不需要將轉碼協議當作參數傳入。并且,當待轉換的二進制對象的字節數超過 pickle 的 Python 對象時,多余的字節將被忽略。
pickle.dump()函數
此函數用于將 Python 對象轉換成二進制文件,其基本語法格式為:
dump?(obj,?file,protocol=None,?*,?fix?mports=True)
其中各個參數的具體含義如下:
-
obj
:要轉換的 Python 對象。 -
file
:轉換到指定的二進制文件中,要求該文件必須是以"wb"的打開方式進行操作。 -
protocol
:和 dumps() 函數中 protocol 參數的含義完全相同,因此這里不再重復描述。 - 其他參數:為了兼容以前 Python 2.x版本而保留的參數,可以忽略。
【例 3】將 tup1 元組轉換成二進制對象文件。
import?pickle tup1?=?('I?love?Python',?{1,2,3},?None) #使用?dumps()?函數將?tup1?轉成?p1 with?open?("a.txt",?'wb')?as?f:?#打開文件 ????pickle.dump(tup1,?f)?#用?dump?函數將?Python?對象轉成二進制對象文件
運行完此程序后,會在該程序文件同級目錄中,生成 a.txt 文件,但由于其內容為二進制數據,因此直接打開會看到亂碼。
pickle.load()函數
此函數和 dump() 函數相對應,用于將二進制對象文件轉換成 Python 對象。該函數的基本語法格式為:
load(file,?*,?fix_imports=True,?encoding='ASCII',?errors='strict')
其中,file 參數表示要轉換的二進制對象文件(必須以 "rb" 的打開方式操作文件),其它參數只是為了兼容 Python 2.x 版本而保留的參數,可以忽略。
【例 4】將例 3 轉換的 a.txt 二進制文件對象轉換為 Python 對象。
import?pickle tup1?=?('I?love?Python',?{1,2,3},?None) #使用?dumps()?函數將?tup1?轉成?p1 with?open?("a.txt",?'wb')?as?f:?#打開文件 ????pickle.dump(tup1,?f)?#用?dump?函數將?Python?對象轉成二進制對象文件 with?open?("a.txt",?'rb')?as?f:?#打開文件 ????t3?=?pickle.load(f)?#將二進制文件對象轉換成?Python?對象 ????print(t3)
運行結果為:
('I love Python', {1, 2, 3}, None)
總結:
看似強大的 pickle 模塊,其實也有它的短板,即 pickle 不支持并發地訪問持久性對象,在復雜的系統環境下,尤其是讀取海量數據時,使用 pickle 會使整個系統的I/O讀取性能成為瓶頸。這種情況下,可以使用 ZODB。
ZODB 是一個健壯的、多用戶的和面向對象的數據庫系統,專門用于存儲 Python 語言中的對象數據,它能夠存儲和管理任意復雜的 Python 對象,并支持事務操作和并發控制。并且,ZODB 也是在 Python 的序列化操作基礎之上實現的,因此要想有效地使用 ZODB,必須先學好 pickle。
原文鏈接:https://juejin.cn/post/7046959646224941087
相關推薦
- 2022-09-14 R語言ggplot2圖例標簽、標題、順序修改和刪除操作實例_R語言
- 2022-09-12 C++實例分析組合數的計算與排列組合的產生_C 語言
- 2023-06-16 pytest中的fixture基本用法_python
- 2022-08-22 詳解C#對Dictionary內容的通用操作_C#教程
- 2022-10-09 Xshell連接不上虛擬機的解決辦法匯總_Linux
- 2022-06-17 Python正則表達式的小練習分享_python
- 2022-07-12 Android Studio與夜神模擬器進行連接以及連接中出現的問題
- 2022-07-04 PyCharm如何配置SSH和SFTP連接遠程服務器_python
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支