網(wǎng)站首頁 編程語言 正文
前言:
在英語中 pickle
名詞是泡菜,動詞是腌漬的意思。可以理解為把東西腌起來保存成文件,要用的時候讀出來洗洗再用。
python
的pickle
模塊實現(xiàn)了基本的數(shù)據(jù)序列化和反序列化。
序列化對象可以在磁盤上保存對象,并在需要的時候讀取出來。任何對象都可以執(zhí)行序列化操作。
pickle的本質(zhì)是將Python數(shù)據(jù)還原為內(nèi)存中的二進(jìn)制數(shù)據(jù),供用戶轉(zhuǎn)移、儲存。
pickle模塊通常會在2種場景下使用:
- 將Python的數(shù)據(jù)保存為磁盤上的二進(jìn)制文件,需要時讀取還原為Python數(shù)據(jù),可以是可打印的基本數(shù)據(jù)(字符串、列表、字典等等),也可以是不可打印的類數(shù)據(jù)。相比之下,使用Json方式只能保存可打印的基本數(shù)據(jù)
- 將已經(jīng)創(chuàng)建好的類數(shù)據(jù)字符串化,保存為一個變量。在程序下次運行時直接讀取變量還原為類數(shù)據(jù),省去類數(shù)據(jù)的創(chuàng)建過程
1 將Python數(shù)據(jù)存儲為本地文件
設(shè)計一個程序,輸出產(chǎn)物是Excel工作簿output.xlsx
,工作簿中有一個工作表out_sheet
是從 標(biāo)準(zhǔn)文檔input.xlsx
中的 in_sheet 中復(fù)制而來。
工作表in_sheet
的內(nèi)容很龐大,難以用手動重現(xiàn),通常我們會選擇將 標(biāo)準(zhǔn)文檔 input.xlsx 作為程序的引用素材放在工程里。程序運行過程中將工作表 in_sheet復(fù)制到工作表out_sheet
中。
如果我們要求不能明文存儲 工作表 in_sheet文件,只能存儲工作表對應(yīng)的Worksheet()
數(shù)據(jù) ,將使用到pickle
模塊
① 存儲過程
import pickle from openpyxl import load_workbook # 創(chuàng)建類數(shù)據(jù) wb = load_workbook('input.xlsx') ws = wb['in_sheet'] # 將 in_sheet 復(fù)制到 out_sheet # 注意,這里的 usr_copy_sheet() 是自定義方式,openpyxl自帶的copy_sheet()不能復(fù)制不同workbook中的worksheet usr_copy_sheet(ws, out_ws) # 將out_ws轉(zhuǎn)化為二進(jìn)制數(shù)據(jù) obj = pickle.dumps(out_ws) # 將二進(jìn)制數(shù)據(jù)存到本地文件,必須使用二進(jìn)制寫入 with open(file='data.txt', mode='wb') as f: ? ? f.write(obj)
此時,ws被存儲到本地文件 data.txt,打開是二進(jìn)制亂碼
② 加載過程
import pickle from openpyxl.worksheet.worksheet import Worksheet # 創(chuàng)建空的類數(shù)據(jù)準(zhǔn)備接收數(shù)據(jù),如果類有parent屬性,必須和要接收的數(shù)據(jù)保持一致 out_ws= Worksheet(parent=out_wb) # 將本地文件數(shù)據(jù)加載到類數(shù)據(jù)上,必須使用二進(jìn)制打開文件 with open(file='data.txt', mode='rb') as f: ? ? out_ws= pickle.loads(f.read())
便可以省去讀取 工作表in_sheet
,復(fù)制到工作表 out_sheet等等過程
2 將Python數(shù)據(jù)存儲為程序的一部分
如果我們要求 工作表in_sheet
文件的數(shù)據(jù)不但不能明文存儲,還不能作為外部文件,必須作為 程序.exe 的一部分,以防丟失。有些小程序一共只有一個 exe文件,外掛一個文件不方便,此時可使用到pickle
模塊
① 存儲過程
import pickle from openpyxl import load_workbook # 創(chuàng)建類數(shù)據(jù) wb = load_workbook('input.xlsx') ws = wb['in_sheet'] # 將 in_sheet 復(fù)制到 out_sheet # 注意,這里的 usr_copy_sheet() 是自定義方式,openpyxl自帶的copy_sheet()不能復(fù)制不同workbook中的worksheet usr_copy_sheet(ws, out_ws) # 將out_ws轉(zhuǎn)化為二進(jìn)制數(shù)據(jù) obj = pickle.dumps(out_ws) # 將二進(jìn)制數(shù)據(jù)存為py文件,必須使用文本寫入 with open(file='out_sheet.py', mode='w') as f: ? ? # 將二進(jìn)制數(shù)據(jù)轉(zhuǎn)為 b'''xxx''' 字符串寫入 py文件 ? ? data = 'data=' + str(obj).replace('b\'', 'b\'\'\'') + '\'\'' ? ? f.write(data)
此時,out_ws
被存儲到本地文件out_sheet.py,內(nèi)容是一串二進(jìn)制碼:
data=b'''\x80\x04......'''
② 加載過程
將生成的out_sheet.py
加載到程序中,直接讀取數(shù)據(jù)
import pickle from openpyxl.worksheet.worksheet import Worksheet import out_sheet # 創(chuàng)建空的類數(shù)據(jù)準(zhǔn)備接收數(shù)據(jù),如果類有parent屬性,必須和要接收的數(shù)據(jù)保持一致 out_ws= Worksheet(parent=out_wb) # 直接讀取out_sheet.py文件中的data變量 out_ws= pickle.loads(out_sheet.data)
out_sheet.py
最終會被編譯為程序的一部分
原文鏈接:https://blog.csdn.net/u011079613/article/details/123302828
相關(guān)推薦
- 2024-01-29 SpringBoot的自動裝配原理
- 2022-02-25 antd4中Form.create已廢棄
- 2022-04-18 python中的selenium實現(xiàn)自動向下滾動頁面并指定最大滑動距離_python
- 2022-11-27 MobLink?Android?快速集成指南_Android
- 2022-09-17 使用cache加快編譯速度的命令詳解_相關(guān)技巧
- 2023-12-16 SpringBoot之自定義Starter
- 2022-06-15 Python中的?any()?函數(shù)和?all()?函數(shù)_python
- 2022-07-22 vi編輯器設(shè)置自定義快捷鍵自動生成c語言的main函數(shù)
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支