序列化的基本概念介紹:python
01
什麼是序列化
序列化:把內存中的數據轉成一種中間格式(json / pickle), 而後存放到硬盤中,永久保存
反序列化:從文件中讀出(json / pickle)格式,而後返解成python的數據類型json
02
爲何要序列化
一、數據結構持久化數據結構
二、跨平臺數據交互ide
03
如何進行序列化,反序列化
json:
缺點:
只能支持部分python的數據類型
優勢:
全部的語言都支持json格式函數
應用:
若是須要考慮跨平臺性,則須要用json格式
pickle
缺點:
只有python支持pickle格式
優勢:
pickle可以支持全部的python數據類型code
應用:
若是不須要考慮跨平臺性,則能夠用pickle格式對象
Import json 內存
import json
dic={'name':'egon','age':18}
print(json.dumps(dic))#{"name": "egon", "age": 18} #python的idc類型就是對應json的{}utf-8
dic={'name':'egon','age':18,'is_beautiful':True}
print(json.dumps(dic))#{"name": "egon", "age": 18, "is_beautiful": true} Python的True對應json的true開發
dic={'name':'egon','age':18,'is_beautiful':True}
res=json.dumps(dic)
print(res,type(res))
{"name": "egon", "age": 18, "is_beautiful": true} <class 'str'> json的tsring對應python的str
序列化: 把字典序列化到文件中的簡單的寫法:
res=json.dumps(dic) # 強調,json格式不識別單引號
with open('user.json','w',encoding='utf-8') as f: #存入到文件user.json能夠不加,提醒是json格式的文件,字符串是wt,能夠省略t,
f.write(res)
反序列化: 如今數據存入到了user.json文件,註釋代碼文件中的內容,此時內存中沒有這個文件,此時要取這個內容要從user.json文件中去拿
with open('user.json','r',encoding='utf-8') as f:
res=f.read()
dic=json.loads(res)
print(dic['name'])
強調,json格式不識別單引號
with open('user1.json','r',encoding='utf-8') as f:
res=f.read()
dic=json.loads(res)
print(dic['x'])
user1.json
{'x':1,'y':true} #反序列化的時候會報錯,# obj,end = self.scan_once(s, idx)#json.decoder.JSONDecodeError: Expecting property name enclosed in double quotes: line 1 column 2 (char 1)
{"x":1,"y":true} #反序列化的時候會報錯,非要用雙引號,不支持單引號,改爲雙引號能取出#egon
簡寫的格式:
序列化:
dic={'name':'egon','age':18,'is_beautiful':True}
with open('user2.json','w',encoding='utf-8') as f:
json.dump(dic,f) #第一個參數是序列化的對象,第二個參數是要打開的文件,sjon.dum能夠直接把字典放入到文件,就不用再掉f.read
反序列化:
with open('user.json', 'r', encoding='utf-8') as f:
dic = json.load(f)
print(dic['name'])
import pickle
序列化:
pickle能夠序列化任意python的數據類型
print(json.dumps({1,2,3}))
print(pickle.dumps({1,2,3}))
dic={'name':'egon','age':18,'is_beautiful':True}
res=pickle.dumps(dic)
with open('user3.pkl','wb') as f:
f.write(res)
反序列化:
with open('user3.pkl','rb') as f:
res=f.read()
dic=pickle.loads(res)
print(dic['name'])
簡單寫法
dic={'name':'egon','age':18,'is_beautiful':True}
with open('user4.pkl','wb') as f:
pickle.dump(dic,f)
with open('user4.pkl', 'rb') as f:
dic = pickle.load(f)
print(dic['name'])
總結:Day-6-8
序列化:python - -->json
反序列化:json - -->python
序列化:
python
dic到json
dumps - --->json - ---->file【open -->write】
dump
反序列化:
loads - ---->read
load
json
支持多平臺,使用與跨平臺項目的開發
pickle只支持python
json格式的字符串,既然是字符串他有兩個用處一、綁定函數,對數據進行持久化二、給別的平臺發