电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

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

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

瀏覽:10日期: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ù)類型和用戶自定義類的對(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é)束以及它的類型信息。 因此,你無(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ù),類,還有接口,但是結(jié)果數(shù)據(jù)僅僅將它們的名稱編碼成對(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í)可用的。 模塊、類和函數(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)部使用。

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

# 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)文章:
主站蜘蛛池模板: 成都热收缩包装机_袖口式膜包机_高速塑封机价格_全自动封切机器_大型套膜机厂家 | 快速卷帘门_硬质快速卷帘门-西朗门业 | 北京亦庄厂房出租_经开区产业园招商信息平台 | 收录网| 橡胶粉碎机_橡胶磨粉机_轮胎粉碎机_轮胎磨粉机-河南鼎聚重工机械制造有限公司 | 哈尔滨发电机,黑龙江柴油发电机组-北方星光 | 百度关键词优化_网站优化_SEO价格 - 云无限好排名 | 建筑资质代办-建筑资质转让找上海国信启航| 塑木弯曲试验机_铜带拉伸强度试验机_拉压力测试台-倾技百科 | 土壤检测仪器_行星式球磨仪_土壤团粒分析仪厂家_山东莱恩德智能科技有限公司 | 英语词典_成语词典_日语词典_法语词典_在线词典网 | 户外环保不锈钢垃圾桶_标识标牌制作_园林公园椅厂家_花箱定制-北京汇众环艺 | 【星耀裂变】_企微SCRM_任务宝_视频号分销裂变_企业微信裂变增长_私域流量_裂变营销 | 动力配电箱-不锈钢配电箱-高压开关柜-重庆宇轩机电设备有限公司 聚天冬氨酸,亚氨基二琥珀酸四钠,PASP,IDS - 远联化工 | 智能家居全屋智能系统多少钱一套-小米全套价格、装修方案 | 中式装修设计_室内中式装修_【云臻轩】中式设计机构 | 量子管通环-自清洗过滤器-全自动反冲洗过滤器-北京罗伦过滤技术集团有限公司 | 铝箔袋,铝箔袋厂家,东莞铝箔袋,防静电铝箔袋,防静电屏蔽袋,防静电真空袋,真空袋-东莞铭晋让您的产品与众不同 | 南京PVC快速门厂家南京快速卷帘门_南京pvc快速门_世界500强企业国内供应商_南京美高门业 | 新能源汽车电池软连接,铜铝复合膜柔性连接,电力母排-容发智能科技(无锡)有限公司 | 飞利浦LED体育场灯具-吸顶式油站灯-飞利浦LED罩棚灯-佛山嘉耀照明有限公司 | 欧美日韩国产一区二区三区不_久久久久国产精品无码不卡_亚洲欧洲美洲无码精品AV_精品一区美女视频_日韩黄色性爱一级视频_日本五十路人妻斩_国产99视频免费精品是看4_亚洲中文字幕无码一二三四区_国产小萍萍挤奶喷奶水_亚洲另类精品无码在线一区 | 净化工程_无尘车间_无尘车间装修-广州科凌净化工程有限公司 | 全温度恒温培养摇床-大容量-立式-远红外二氧化碳培养箱|南荣百科 | 奇酷教育-Python培训|UI培训|WEB大前端培训|Unity3D培训|HTML5培训|人工智能培训|JAVA开发的教育品牌 | 卷筒电缆-拖链电缆-特种柔性扁平电缆定制厂家「上海缆胜」 | 定制/定做衬衫厂家/公司-衬衫订做/订制价格/费用-北京圣达信 | 手板_手板模型制作_cnc手板加工厂-东莞天泓 | 培训一点通 - 合肥驾校 - 合肥新亚驾校 - 合肥八一驾校 | 磁力反应釜,高压釜,实验室反应釜,高温高压反应釜-威海自控反应釜有限公司 | 水质监测站_水质在线分析仪_水质自动监测系统_多参数水质在线监测仪_水质传感器-山东万象环境科技有限公司 | 中细软知识产权_专业知识产权解决方案提供商 | 成都思迪机电技术研究所-四川成都思迪编码器 | 手机存放柜,超市储物柜,电子储物柜,自动寄存柜,行李寄存柜,自动存包柜,条码存包柜-上海天琪实业有限公司 | 找果网 | 苹果手机找回方法,苹果iPhone手机丢了找回,认准找果网! | 可程式恒温恒湿试验箱|恒温恒湿箱|恒温恒湿试验箱|恒温恒湿老化试验箱|高低温试验箱价格报价-广东德瑞检测设备有限公司 | 翰香原枣子坊加盟费多少钱-正宗枣核糕配方培训利润高飘香 | 知企服务-企业综合服务(ZiKeys.com)-品优低价、种类齐全、过程管理透明、速度快捷高效、放心服务,知企专家! | LED灯杆屏_LED广告机_户外LED广告机_智慧灯杆_智慧路灯-太龙智显科技(深圳)有限公司 | 学校用栓剂模,玻璃瓶轧盖钳,小型安瓿熔封机,实验室安瓿熔封机-长沙中亚制药设备有限公司 | 中国品牌排名投票_十大品牌榜单_中国著名品牌【中国品牌榜】 |