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

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

序列化Python對(duì)象的方法

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

問(wèn)題

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

解決方案

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

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

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

s = pickle.dumps(data)

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

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

討論

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

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

>>> 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ù),類(lèi),還有接口,但是結(jié)果數(shù)據(jù)僅僅將它們的名稱(chēng)編碼成對(duì)應(yīng)的代碼對(duì)象。例如:

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

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

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

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

試著運(yùn)行下面的序列化試驗(yà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解析器并重啟后再試驗(yàn)下:

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

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

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

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

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

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

標(biāo)簽: Python 編程
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
欧美日韩国产精品一区二区亚洲| 亚洲一区网站| 中文字幕一区二区三区日韩精品| 欧美特黄一区| 国产中文一区| 亚洲成人不卡| 久久久久免费av| 欧美日韩精品一区二区视频| 欧美日韩视频免费观看| 中文字幕人成乱码在线观看| 国产麻豆一区二区三区 | 亚洲不卡av不卡一区二区| 日韩欧美一区二区三区免费观看| 国产91在线精品| 香蕉成人av| 视频一区视频二区中文字幕| 亚洲精品系列| 国产精品白丝av嫩草影院| 精品亚洲免a| 久久中文字幕二区| 亚洲久久一区| 麻豆国产精品777777在线| 美女av在线免费看| 国产 日韩 欧美 综合 一区| 国产精品一区二区免费福利视频| 亚洲欧美一级| 蜜臀精品久久久久久蜜臀| 亚洲欧美网站| 黄色日韩在线| 国产视频一区二| 国产精品99久久免费| 免费在线亚洲欧美| 大香伊人久久精品一区二区| 亚洲黄色免费看| 久久久久久久久99精品大| 欧美精品一二| 中文精品视频| 在线国产精品一区| 亚洲高清激情| 久久福利影视| 最新国产精品视频| 精品亚洲成人| 日韩精品永久网址| 热久久久久久久| 国产欧美一区二区色老头| 精品黄色一级片| 久久视频精品| 免费视频一区二区| 中文视频一区| 国产美女撒尿一区二区| 欧美精选一区二区三区| 日韩影院在线观看| 欧美一区网站| 亚洲一二av| 97精品国产99久久久久久免费| 日韩国产欧美一区二区三区| 国产精品亚洲欧美| 青青久久av| 鲁大师成人一区二区三区| 国产精品国码视频| 久久国产主播| 99国产精品| 国产成人精品一区二区三区免费 | 国产欧美啪啪| sm久久捆绑调教精品一区| 夜夜嗨一区二区三区| 婷婷精品在线观看| 高清一区二区三区| 野花国产精品入口| 国产精品videossex| 日韩88av| 欧美精品影院| 99成人在线视频| 国产精品国码视频| 中文亚洲欧美| 激情视频网站在线播放色| 蜜臀a∨国产成人精品| 国产日本精品| 亚洲h色精品| 久久激情五月婷婷| 亚洲欧洲一区| 国产九九精品| 亚洲无线观看| 色88888久久久久久影院| 国产日韩欧美一区| 黑丝一区二区三区| 成人亚洲一区| 日本精品国产| 日韩亚洲国产欧美| 日韩免费一区| 精品成av人一区二区三区 | 五月婷婷六月综合| 欧美精品不卡| 日韩av不卡一区二区| 国产盗摄——sm在线视频| 欧美精品国产白浆久久久久| 亚洲午夜视频| 国产二区精品| 国产一区二区三区久久久久久久久| 亚洲1234区| 精品一区二区三区中文字幕| 少妇精品久久久一区二区三区| 少妇精品导航| 麻豆精品国产91久久久久久| 日本视频在线一区| 欧美综合二区| 亚洲欧美激情诱惑| 亚洲爱爱视频| 麻豆高清免费国产一区| 日韩和欧美的一区| 国产精品一区二区99| 鲁大师影院一区二区三区| 亚洲深夜视频| 中文在线免费视频| 欧美aaaaaa午夜精品| 国产精品a级| 91精品国产自产在线丝袜啪| 日本中文字幕一区二区视频 | 欧美手机在线| 91日韩在线| 国产精品资源| 日韩精品亚洲专区| 日韩一区二区三区四区五区| 日韩精品免费一区二区在线观看| 美女在线视频一区| 精品在线网站观看| 亚洲激情欧美| 久久成人一区| 福利在线免费视频| 免费看久久久| 蜜臀av一区二区三区| 国产亚洲在线观看| 91福利精品在线观看| 亚洲激精日韩激精欧美精品| 日韩精品免费一区二区在线观看| 久久亚洲黄色| 国产精品久久久久77777丨| 国产精品久久久免费| 快she精品国产999| 免费观看久久久4p| 国产色综合网| 视频一区中文字幕精品| 伊人久久一区| 人人爱人人干婷婷丁香亚洲| 日韩不卡在线观看日韩不卡视频| 国产剧情在线观看一区| 国产精品二区影院| 久久精品国产亚洲aⅴ| 久久91导航| 九一成人免费视频| 亚洲精一区二区三区| 中文字幕av一区二区三区四区| 91福利精品在线观看| 亚洲毛片在线免费| 免费成人网www| 久久一二三区| 日本中文字幕一区二区| 日本不卡视频在线观看| 国产欧美一区二区精品久久久 | 少妇精品导航| 亚洲国产成人精品女人| 亚洲天堂日韩在线| 欧美亚洲免费| 四虎8848精品成人免费网站| 国产精品久久久久蜜臀| japanese国产精品| 天堂日韩电影| 亚洲激精日韩激精欧美精品| 亚洲一区二区毛片| 在线成人直播| 亚洲精品福利| 国产精品久久久久久久久免费高清 | 日韩国产欧美一区二区三区| 国产欧美亚洲精品a| 欧美国产专区| 国产综合婷婷| 亚洲精品乱码久久久久久蜜桃麻豆| 免费一级欧美片在线观看网站| 国产精品亚洲综合久久| 久久久久国产| 亚州精品视频| 日韩国产激情| 香蕉精品999视频一区二区| 国产精品日本一区二区三区在线| 久草精品视频| 亚洲欧美日韩视频二区| 欧美永久精品| 1000部精品久久久久久久久| 亚洲视频国产| av高清不卡| 日韩视频一区| 久久精品国产999大香线蕉| 夜鲁夜鲁夜鲁视频在线播放| 免费国产亚洲视频| 国产精品黄色| 亚洲人www| 欧美日韩精品免费观看视完整 | 亚洲狼人精品一区二区三区| 欧美成人一二区| 亚洲一二av|