麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > Python > 正文

實例講解python中的序列化知識點

2020-02-15 23:07:21
字體:
來源:轉載
供稿:網友

在程序運行的過程中,所有的變量都是在內存中,比如,定義一個dict:

d = dict(name='Bob', age=20, score=88)

可以隨時修改變量,比如把name改成'Bill',但是一旦程序結束,變量所占用的內存就被操作系統全部回收。如果沒有把修改后的'Bill'存儲到磁盤上,下次重新運行程序,變量又被初始化為'Bob'。

我們把變量從內存中變成可存儲或傳輸的過程稱之為序列化,在Python中叫pickling,在其他語言中也被稱之為serialization,marshalling,flattening等等,都是一個意思。

序列化之后,就可以把序列化后的內容寫入磁盤,或者通過網絡傳輸到別的機器上。

反過來,把變量內容從序列化的對象重新讀到內存里稱之為反序列化,即unpickling。

Python提供了pickle模塊來實現序列化。

首先,我們嘗試把一個對象序列化并寫入文件:

>>> import pickle>>> d = dict(name='Bob', age=20, score=88)>>> pickle.dumps(d)b'/x80/x03}q/x00(X/x03/x00/x00/x00ageq/x01K/x14X/x05/x00/x00/x00scoreq/x02KXX/x04/x00/x00/x00nameq/x03X/x03/x00/x00/x00Bobq/x04u.'

pickle.dumps()方法把任意對象序列化成一個bytes,然后,就可以把這個bytes寫入文件。或者用另一個方法pickle.dump()直接把對象序列化后寫入一個file-like Object:

>>> f = open('dump.txt', 'wb')>>> pickle.dump(d, f)>>> f.close()

看看寫入的dump.txt文件,一堆亂七八糟的內容,這些都是Python保存的對象內部信息。

當我們要把對象從磁盤讀到內存時,可以先把內容讀到一個bytes,然后用pickle.loads()方法反序列化出對象,也可以直接用pickle.load()方法從一個file-like Object中直接反序列化出對象。我們打開另一個Python命令行來反序列化剛才保存的對象:

>>> f = open('dump.txt', 'rb')>>> d = pickle.load(f)>>> f.close()>>> d{'age': 20, 'score': 88, 'name': 'Bob'}

變量的內容又回來了!

當然,這個變量和原來的變量是完全不相干的對象,它們只是內容相同而已。

Pickle的問題和所有其他編程語言特有的序列化問題一樣,就是它只能用于Python,并且可能不同版本的Python彼此都不兼容,因此,只能用Pickle保存那些不重要的數據,不能成功地反序列化也沒關系。

以上就是本篇文章所講述的所有內容,這篇文章主要介紹了python序列化的相關知識,希望你能借助資料從而理解上述所說的內容。希望我在這片文章所講述的內容能夠對你有所幫助,讓你學習python更加輕松。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 性明星video另类hd | 青青草华人在线 | 蜜桃传媒视频麻豆第一区免费观看 | 国产精品爱久久久久久久 | arabxxxxvideos| 精品久久久久久综合日本 | 极品xxxx欧美一区二区 | 钻石午夜影院 | 日本欧美一区二区三区在线观看 | 亚洲成人精品国产 | 日韩av成人| 一区二区三高清 | 自拍亚洲伦理 | 亚洲人成网站免费播放 | 日本高清在线免费 | 欧美人的天堂一区二区三区 | 国产一级二级在线播放 | 蜜桃视频最新网址 | 成人资源在线 | 久久精品亚洲一区二区三区观看模式 | 久久久日韩精品一区二区 | 免费一级毛片在线播放视频 | 性欧美在线视频 | 国产成人精品网站 | 亚洲国产精品久久久 | 亚洲第一激情网 | 国产免费一级 | 日韩av电影免费在线观看 | 日韩伦理电影免费观看 | 国产一级一区二区三区 | 久久探花 | 欧美一极视频 | 亚洲 91 | 国产激情视频在线 | 99热久草 | 性少妇videosexfreexx | 久久精品中文字幕一区二区三区 | 87成人免费看片 | av成人在线电影 | 九九精品在线播放 | 久久久久久久久久亚洲 |