一、序列化與反序列化的概念
# 把物件轉換為位元組序列的過程稱為物件的序列化。
把位元組序列還原為物件的過程稱為物件的反序列化。
物件的序列化主要有兩種用途:
1) 把物件的位元組序列永久地儲存到硬碟上,通常存放在一個檔案中;
2) 在網路上傳送物件的字節序列。
在許多應用中,需要對某些物件進行序列化,讓它們離開記憶體空間,入住實體硬碟,以便長期保存。例如最常見的是Web伺服器中的Session對象,當有10萬用戶並發訪問,就有可能出現10萬個Session對象,內存可能吃不消,於是Web容器就會把一些seesion先序列化到硬碟中,等要用了,再把保存在硬碟中的物件還原到記憶體中。
當兩個行程在進行遠端通訊時,彼此可以傳送各種類型的資料。無論是何種類型的數據,都會以二元序列的形式在網路上傳送。發送方需要把這個Java物件轉換為位元組序列,才能在網路上傳送;接收方則需要把位元組序列再恢復為Java物件。
json序列化的過程,就是寫入檔案中,讓另一個程式語言進行呼叫:
import json
info = {"alex":"sb","test":"hard"}
with open("file","w") as f:
f.write(json.dumps(info))
上述程式碼使用json將info字典資訊寫入到一個檔案中,檔案中只能儲存字串格式的信息,或二進位檔案的信息,不能存放數字等信息,放入檔案的資訊都是字串類型的,這點一定要注意.
json反序列化的過程:
import json
# '''反序列化起始就是把dump進去的資訊擷取,以實作不同程式語言的互動'''
with open("file","r") as f:
data = json.loads(f.read())
print(data)
#print(data) print(
type(data)) print(data["alex"])
######## ################################# ############ 上面程式碼,將使用json格式存入的資訊讀取出來,如下所示:#######
{'test': 'hard', 'alex': 'sb'}
sb
上述程式碼實作了將字串資訊讀出取問字典的功能,其實,序列化和反序列化就是將原來的格式先轉化為字串,然後在讀取出來的過程,以便能夠實現交互.
我們也可以使用其他方式進行序列化和反序列化,我們知道,有一個函數eval(),能夠實現把字串資訊轉換為原本樣式,如下:
info = [11,22,33,65,33]
# with open ("test.text","w") as f:
f.write(str(info)) #使用wirte ()只能寫入檔案中字串格式的訊息,不能寫入其他類型的訊息
with open("test.text","r") as f_obj:
data = f_obj.read()
data = data))
print(data)
程式執行如下:
# dump序列化:############ ###import json###### info = {###"alex":###"sb",### "test":###"hard"}######### with ###open(###"file",###"w") ###as f:### json .dump(info,f)########################################## load ()反序列化:######
import json
'''反序列化起始就是把dump進去的資訊進行提取,以實現不同編程語言的互動'''
with open("file","r") as f:
data = json.load(f)
print(data)
print(type(data))
#o#") ])
上面程式實現了序列化和反序列化的功能,dump(訊息,檔案路徑),load(檔案路徑),從哪個檔案讀取資訊.
在不同程式間實作資料的交換.
不同程式之間的資料交換,或將字串的資訊轉換成原有的形式;
eval ()
函數的功能也很強大,能夠之間將字串形式的信息轉換為原有的信息,如下:
>>> dic = "{'alex':'sb','try':'workhard'}"
>>> data = eval(dic) >>> data
{'try ': 'workhard', 'alex': 'sb'}
### 程式只dump一次,load一次,不能dump多次. dumps好幾個檔案實作;######以上是序列化和反序列化的詳細介紹的詳細內容。更多資訊請關注PHP中文網其他相關文章!