日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

序列化Python對象的方法

瀏覽:60日期:2022-07-15 14:35:11

問題

你需要將一個Python對象序列化為一個字節(jié)流,以便將它保存到一個文件、存儲到數(shù)據(jù)庫或者通過網(wǎng)絡(luò)傳輸它。

解決方案

對于序列化最普遍的做法就是使用 pickle 模塊。為了將一個對象保存到一個文件中,可以這樣做:

import pickledata = ... # Some Python objectf = open(’somefile’, ’wb’)pickle.dump(data, f)

為了將一個對象轉(zhuǎn)儲為一個字符串,可以使用 pickle.dumps() :

s = pickle.dumps(data)

為了從字節(jié)流中恢復(fù)一個對象,使用 pickle.load() 或 pickle.loads() 函數(shù)。比如:

# Restore from a filef = open(’somefile’, ’rb’)data = pickle.load(f)# Restore from a stringdata = pickle.loads(s)

討論

對于大多數(shù)應(yīng)用程序來講,dump() 和 load() 函數(shù)的使用就是你有效使用 pickle 模塊所需的全部了。 它可適用于絕大部分Python數(shù)據(jù)類型和用戶自定義類的對象實例。 如果你碰到某個庫可以讓你在數(shù)據(jù)庫中保存/恢復(fù)Python對象或者是通過網(wǎng)絡(luò)傳輸對象的話, 那么很有可能這個庫的底層就使用了 pickle 模塊。

pickle 是一種Python特有的自描述的數(shù)據(jù)編碼。 通過自描述,被序列化后的數(shù)據(jù)包含每個對象開始和結(jié)束以及它的類型信息。 因此,你無需擔(dān)心對象記錄的定義,它總是能工作。 舉個例子,如果要處理多個對象,你可以這樣做:

>>> import pickle>>> f = open(’somedata’, ’wb’)>>> pickle.dump([1, 2, 3, 4], f)>>> pickle.dump(’hello’, f)>>> pickle.dump({’Apple’, ’Pear’, ’Banana’}, f)>>> f.close()>>> f = open(’somedata’, ’rb’)>>> pickle.load(f)[1, 2, 3, 4]>>> pickle.load(f)’hello’>>> pickle.load(f){’Apple’, ’Pear’, ’Banana’}>>>

你還能序列化函數(shù),類,還有接口,但是結(jié)果數(shù)據(jù)僅僅將它們的名稱編碼成對應(yīng)的代碼對象。例如:

>>> import math>>> import pickle.>>> pickle.dumps(math.cos)b’x80x03cmathncosnqx00.’>>>

當(dāng)數(shù)據(jù)反序列化回來的時候,會先假定所有的源數(shù)據(jù)時可用的。 模塊、類和函數(shù)會自動按需導(dǎo)入進(jìn)來。對于Python數(shù)據(jù)被不同機器上的解析器所共享的應(yīng)用程序而言, 數(shù)據(jù)的保存可能會有問題,因為所有的機器都必須訪問同一個源代碼。

千萬不要對不信任的數(shù)據(jù)使用pickle.load()。pickle在加載時有一個副作用就是它會自動加載相應(yīng)模塊并構(gòu)造實例對象。但是某個壞人如果知道pickle的工作原理,他就可以創(chuàng)建一個惡意的數(shù)據(jù)導(dǎo)致Python執(zhí)行隨意指定的系統(tǒng)命令。因此,一定要保證pickle只在相互之間可以認(rèn)證對方的解析器的內(nèi)部使用。

有些類型的對象是不能被序列化的。這些通常是那些依賴外部系統(tǒng)狀態(tài)的對象, 比如打開的文件,網(wǎng)絡(luò)連接,線程,進(jìn)程,棧幀等等。 用戶自定義類可以通過提供 __getstate__() 和 __setstate__() 方法來繞過這些限制。 如果定義了這兩個方法,pickle.dump() 就會調(diào)用 __getstate__() 獲取序列化的對象。 類似的,__setstate__() 在反序列化時被調(diào)用。為了演示這個工作原理, 下面是一個在內(nèi)部定義了一個線程但仍然可以序列化和反序列化的類:

# countdown.pyimport timeimport threadingclass Countdown: def __init__(self, n): self.n = n self.thr = threading.Thread(target=self.run) self.thr.daemon = True self.thr.start() def run(self): while self.n > 0: print(’T-minus’, self.n) self.n -= 1 time.sleep(5) def __getstate__(self): return self.n def __setstate__(self, n): self.__init__(n)

試著運行下面的序列化試驗代碼:

>>> import countdown>>> c = countdown.Countdown(30)>>> T-minus 30T-minus 29T-minus 28...>>> # After a few moments>>> f = open(’cstate.p’, ’wb’)>>> import pickle>>> pickle.dump(c, f)>>> f.close()

然后退出Python解析器并重啟后再試驗下:

>>> f = open(’cstate.p’, ’rb’)>>> pickle.load(f)countdown.Countdown object at 0x10069e2d0>T-minus 19T-minus 18...

你可以看到線程又奇跡般的重生了,從你第一次序列化它的地方又恢復(fù)過來。

pickle 對于大型的數(shù)據(jù)結(jié)構(gòu)比如使用 array 或 numpy 模塊創(chuàng)建的二進(jìn)制數(shù)組效率并不是一個高效的編碼方式。 如果你需要移動大量的數(shù)組數(shù)據(jù),你最好是先在一個文件中將其保存為數(shù)組數(shù)據(jù)塊或使用更高級的標(biāo)準(zhǔn)編碼方式如HDF5 (需要第三方庫的支持)。

由于 pickle 是Python特有的并且附著在源碼上,所有如果需要長期存儲數(shù)據(jù)的時候不應(yīng)該選用它。 例如,如果源碼變動了,你所有的存儲數(shù)據(jù)可能會被破壞并且變得不可讀取。 坦白來講,對于在數(shù)據(jù)庫和存檔文件中存儲數(shù)據(jù)時,你最好使用更加標(biāo)準(zhǔn)的數(shù)據(jù)編碼格式如XML,CSV或JSON。 這些編碼格式更標(biāo)準(zhǔn),可以被不同的語言支持,并且也能很好的適應(yīng)源碼變更。

最后一點要注意的是 pickle 有大量的配置選項和一些棘手的問題。 對于最常見的使用場景,你不需要去擔(dān)心這個,但是如果你要在一個重要的程序中使用pickle去做序列化的話, 最好去查閱一下 官方文檔 。

以上就是序列化Python對象的方法的詳細(xì)內(nèi)容,更多關(guān)于序列化Python對象的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: Python 編程
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
欧美特黄一级大片| 日本特黄久久久高潮| 老鸭窝一区二区久久精品| 国产精品s色| 国产精品sm| 国产成人精品一区二区三区免费| 精品国产中文字幕第一页| 国产精品777777在线播放| 久久精品国产久精国产| a国产在线视频| 欧美亚洲激情| 视频一区二区三区在线| 日本久久一区| 高清在线一区| 欧美少妇精品| 亚洲午夜精品久久久久久app| 亚洲综合日本| 日韩av成人高清| 福利一区在线| 亚洲欧洲一区| 日韩精品高清不卡| 久久精品五月| 久久一级电影| 中文字幕av一区二区三区人| 欧美午夜三级| 日韩在线观看不卡| 深夜日韩欧美| 精品国产a一区二区三区v免费| 成人精品天堂一区二区三区| 91精品推荐| 日韩在线网址| 日韩一区自拍| 偷拍亚洲精品| 日韩国产在线| 蜜桃久久av一区| 岛国精品一区| 综合激情婷婷| 三级精品视频| 欧美一区二区三区久久精品| 一区二区三区四区日本视频| 蜜臀久久久99精品久久久久久| 精品国产乱码久久久| 久久xxxx| 精品九九在线| 一区二区不卡| 精品日韩视频| 国产精品1luya在线播放| 欧美午夜精品一区二区三区电影| 日韩欧美美女在线观看| 久久九九电影| 国产精品xvideos88| 黄色成人91| 国产一区二区视频在线看| 蜜桃视频在线观看一区| 亚洲不卡av不卡一区二区| 国产亚洲欧美日韩在线观看一区二区| 欧美日一区二区| 成人在线视频免费| 日韩精品一区二区三区免费视频| 欧美成人精品三级网站| 国产探花一区二区| 午夜在线精品| 激情六月综合| 日韩在线观看不卡| 国产成人免费精品| 国产调教一区二区三区| 在线精品观看| 黄色成人精品网站| 成人自拍av| 精品一区二区三区视频在线播放 | 日韩天堂av| 青青青免费在线视频| 国产精品一在线观看| 亚洲影院天堂中文av色| 欧美日韩国产欧| 免费av一区二区三区四区| 日韩.com| 粉嫩av一区二区三区四区五区 | 99国产精品99久久久久久粉嫩| 91亚洲人成网污www| 国产精品久久久久久妇女| 亚洲2区在线| 久久av在线| 亚洲一区黄色| 国产毛片一区| 亚洲一区二区三区高清| 在线视频精品| 亚洲一区亚洲| 午夜在线观看免费一区| 尤物tv在线精品| 私拍精品福利视频在线一区| 久久精品国产亚洲一区二区三区| 日本亚洲最大的色成网站www| 蘑菇福利视频一区播放| 亚洲经典在线| 中文字幕av亚洲精品一部二部| 亚洲一区国产| 中文字幕视频精品一区二区三区| 亚洲视频二区| 亚洲欧美日本视频在线观看| 日韩一级网站| 中文字幕成人| 国产日韩在线观看视频| 国产精品第十页| 欧美国产先锋| 日韩1区在线| 91精品国产乱码久久久久久久| 免费观看不卡av| 日韩在线a电影| 日韩国产欧美在线播放| 国产精品美女午夜爽爽| 国产一区二区三区黄网站| 国产精品高颜值在线观看| 六月婷婷综合| 欧美精选一区二区三区| 久久成人亚洲| 国产欧美日韩| 国产资源在线观看入口av| 欧美中文一区二区| 亚洲午夜免费| 国产精品亚洲综合久久| 欧美激情视频一区二区三区免费 | 国产精品夜夜夜| 女生影院久久| 亚洲高清影视| 免费久久99精品国产自在现线| 亚洲精品在线国产| 国产精品中文字幕亚洲欧美| 精品一区91| 亚洲成人三区| 欧美日韩精品一区二区三区视频| 精品深夜福利视频| 在线国产一区二区| 久久精品av麻豆的观看方式| 国产成人免费视频网站视频社区| 999久久久国产精品| 日韩中文字幕91| 国产精品a久久久久| 韩国精品主播一区二区在线观看 | 精品中国亚洲| 午夜在线精品| 国产一区二区三区黄网站| 伊人精品视频| 国产欧美精品| 日韩精品不卡一区二区| 免播放器亚洲| 福利欧美精品在线| 五月天久久网站| 国产伦一区二区三区| 日韩欧美一区二区三区在线视频 | 精品精品久久| 爽爽淫人综合网网站| 你懂的国产精品永久在线| 久久精品不卡| 国产午夜久久av| av不卡免费看| 国产suv精品一区二区四区视频| 久久亚洲国产精品一区二区| 国产激情久久| 亚洲欧美激情诱惑| 国产成人免费| 亚洲精品福利| 精品中文一区| 麻豆成人91精品二区三区| 蜜臀av免费一区二区三区| 久久99国产精品视频| 亚洲精品影视| 1024精品一区二区三区| 久久不卡日韩美女| 免费观看不卡av| 国内精品麻豆美女在线播放视频| 男女男精品网站| 欧美色图国产精品| 丁香婷婷久久| 欧美日韩中出| 中文字幕一区二区三区日韩精品 | 亚洲视频国产| 国产精品88久久久久久| 国产成人77亚洲精品www| 久久国产精品免费精品3p | 91成人在线| 男女男精品网站| 伊人成人网在线看| 国内精品99| 国产 日韩 欧美一区| 精品久久电影| 91精品美女| 亚洲精品乱码久久久久久蜜桃麻豆| 欧美亚洲精品在线| 免费观看亚洲| 色乱码一区二区三区网站| 午夜久久av| 亚洲精品少妇| 中文字幕亚洲影视| 丝袜亚洲精品中文字幕一区| 久久久水蜜桃av免费网站| 久久精品午夜| 精品一区二区三区视频在线播放| 国产精品一二| 麻豆国产欧美一区二区三区 |