淺析Python 序列化與反序列化
序列化是將對象的狀態(tài)信息轉(zhuǎn)換為可以存儲或傳輸?shù)男问降倪^程。在序列化期間,對象將其當(dāng)前狀態(tài)(存在內(nèi)存中)寫入到臨時或持久性存儲區(qū)(硬盤)。以后,可以通過從存儲區(qū)中讀取或反序列化對象的狀態(tài),重新創(chuàng)建該對象。
實現(xiàn)對象的序列化和反序列化在python中有兩種方式:json 和 pickle。
其中json用于字符串 和 python數(shù)據(jù)類型間進(jìn)行轉(zhuǎn)換,pickle用于python特有的類型 和 python的數(shù)據(jù)類型間進(jìn)行轉(zhuǎn)換,pickle是python特有的。
1、JSON序列化:json.dumps()
info = {
"name":"tj",
"age":22
}
import json
print(info)
print(type(info))
print(json.dumps(info))
print(type(json.dumps(info)))
f = open("test.txt","w")
# f.write(info) # TypeError: write() argument must be str, not dict
f.write(json.dumps(info)) # 正常寫入文件 f.write(json.dumps(info)) 等價于 json.dump(info, f)
f.close()
>>>
{'name': 'tj', 'age': 22}
<class 'dict'>
{"name": "tj", "age": 22}
<class 'str'>
2、JSON反序列化:json.loads()
f = open("test.txt","r")
# print(f.read()["age"]) #TypeError: string indices must be integers
data = json.loads(f.read()) # data = json.loads(f.read()) 等價于 data = json.load(f)
print(data["age"])
f.close()
>>>
22
注意:對于以下這種情況json就不能處理了
import json
def hello(name):
print("hello,",name)
info = {
"name":"tj",
"age":22,
"func":hello
}
f = open("test2.txt","w")
f.write(json.dumps(info)) #TypeError: Object of type function is not JSON serializable
f.close()
所以:json用于字符串 和 python數(shù)據(jù)類型間進(jìn)行轉(zhuǎn)換
3、pickle序列化:pickle.dumps()
import pickle
def hello(name):
print("hello,",name)
info = {
"name":"tj",
"age":22,
"func":hello
}
print(pickle.dumps(info)) #可見pickle序列化的結(jié)果輸出為二進(jìn)制,所以應(yīng)使用wb的方式往文件中寫
f = open("test2.txt","wb")
f.write(pickle.dumps(info)) # 等價于 pickle.dump(info,f)
f.close()
>>>
b'\x80\x04\x957\x00\x00\x00\x00\x00\x00\x00}\x94(\x8c\x04name\x94\x8c\x04alex\x94\x8c\x03age\x94K\x16\x8c\x04func\x94\x8c\x08__main__\x94\x8c\x05hello\x94\x93\x94u.'
對于函數(shù)hello,序列化的不是內(nèi)存地址,而是整個數(shù)據(jù)對象,函數(shù)可以序列化。
4、pickle反序列化:pickle.loads()
f = open("test2.txt","rb")
data = pickle.loads(f.read()) # 等價于data = pickle.load(f)
print(data)
print(data["name"])
print(data["func"])
>>>
{'name': 'tj', 'age': 22, 'func': <function hello at 0x00000179EF69C040>}
tj
<function hello at 0x00000179EF69C040>
5、多次序列化與反序列化
1)json
import json
info = {
"name":"tj",
"age":22
}
f = open("test3.txt","w")
f.write(json.dumps(info))
info['age'] = 21
f.write(json.dumps(info))
f.close()
#
>>>
序列化兩次后test3中的內(nèi)容
test3.txt: {"name": "tj", "age": 22}{"name": "tj", "age": 21}
f = open("test3.txt","r")
# 報錯,py3以上,多次dumps的文件反序列化報錯,py2多次dumps的文件也能被反序列化,先序列化的先被反序列化
data = json.loads(f.read()) # json.decoder.JSONDecodeError
f.close()
print(data)
2)pickle
import pickle
info = {
"name":"tj",
"age":22
}
f = open("test2.txt","wb")
f.write(pickle.dumps(info)) # 等價于 pickle.dump(info,f)
info["sex"] = "女"
f.write(pickle.dumps(info)) # 等價于 pickle.dump(info,f)
f.close()
>>>
序列化兩次后test2.txt中的內(nèi)容
test2.txt: �� }�(�name攲tj攲age擪u.��% }�(�name攲tj攲age擪�sex攲濂硵u.
f = open("test2.txt","rb")
data = pickle.loads(f.read()) # 第一次反序列化正常
# data = pickle.loads(f.read()) # 第二次反序列化:EOFError: Ran out of input
print(data)
print(data["age"])
# print(data["sex"]) # KeyError: 'sex'
老王:是不是就不能多次序列化呢?那我修改后的數(shù)據(jù)還需要序列化寫入到文件怎么辦?
你:當(dāng)然能多次序列化,把序列化后數(shù)據(jù)寫到多個文件不就好了嘛。
以上就是淺析Python 序列化與反序列化的詳細(xì)內(nèi)容,更多關(guān)于Python 序列化與反序列化的資料請關(guān)注腳本之家其它相關(guān)文章!
- Python序列化與反序列化pickle用法實例
- Python3.5 Json與pickle實現(xiàn)數(shù)據(jù)序列化與反序列化操作示例
- Python pickle類庫介紹(對象序列化和反序列化)
- Python 序列化和反序列化庫 MarshMallow 的用法實例代碼
- Python實現(xiàn)的序列化和反序列化二叉樹算法示例
- Python Json序列化與反序列化的示例
- Python實現(xiàn)JSON反序列化類對象的示例
- 詳解Python 序列化Serialize 和 反序列化Deserialize
- 老生常談Python序列化和反序列化
- 詳解Python中的序列化與反序列化的使用
- python3序列化與反序列化用法實例
- Python使用pickle進(jìn)行序列化和反序列化的示例代碼
相關(guān)文章
Python實現(xiàn)通過解析域名獲取ip地址的方法分析
這篇文章主要介紹了Python實現(xiàn)通過解析域名獲取ip地址的方法,結(jié)合實例形式總結(jié)分析了兩種比較常見的解析域名對應(yīng)IP地址相關(guān)操作技巧,需要的朋友可以參考下2019-05-05
基于PyQt5實現(xiàn)的Windows定時關(guān)機(jī)工具
在日常使用電腦的過程中,我們經(jīng)常會遇到需要定時關(guān)機(jī)的場景,雖然 Windows 自帶 shutdown 命令可以定時關(guān)機(jī),但操作方式較為繁瑣,缺乏可視化界面,因此,本篇文章將帶大家實現(xiàn)一個基于 PyQt5 的 Windows 定時關(guān)機(jī)工具,需要的朋友可以參考下2025-04-04
Python字符串通過''+''和join函數(shù)拼接新字符串的性能測試比較
今天小編就為大家分享一篇關(guān)于Python字符串通過'+'和join函數(shù)拼接新字符串的性能測試比較,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2019-03-03
Python使用百度翻譯開發(fā)平臺實現(xiàn)英文翻譯為中文功能示例
這篇文章主要介紹了Python使用百度翻譯開發(fā)平臺實現(xiàn)英文翻譯為中文功能,結(jié)合實例形式分析了Python使用request請求與百度翻譯API接口交互實現(xiàn)翻譯功能相關(guān)操作技巧,需要的朋友可以參考下2019-08-08

