json模塊、pickle模塊(序列化)shelve模塊
阿新 • • 發佈:2018-06-16
under font date style 類型 val int 變量 pytho
json模塊:
json:與任何語言之間都可以進行信息交換(字符串的轉換)
經過json轉換,所有類型均可先轉換為雙引號形式 再轉換為str
例如:文件的讀寫:
1 #寫文件: 2 import json 3 f = open("demo.txt","w") 4 dic = {"name":"g_l"} 5 dic_str = json.dumps(dic) 6 f.write(dic_str) 7 print(type(dic_str)) 8 print(dic_str)
1 #讀文件: 2 import json 3 f = open("demo.txt","r") 4 f_read = f.read()5 f_read = json.loads(f_read) 6 print(type(f_read)) 7 print(type(f_read))
僅僅針對文件操作的 load和dump:【dic f 參考上面兩個代碼】
json.dump(dic,f)
json.load(f)
packle模塊:(支持函數、類等)
序列化:把變量(對象)從內存中變成可存儲或者傳輸的過程稱為序列化
1 import pickle 2 dic = {"name":"alex","name":"g_l","age":18} 3 # print(type(dic)) 4 j = pickle.dumps(dic)View Code5 print(type(j))#字節類型 6 print(j) 7 f = open("序列化對象_pickle",‘wb‘) 8 pickle.dump(dic,f)#f.write()#不可讀文件 9 f.close() 10 # #---反序列化: 11 import pickle 12 f = open("序列化對象_pickle",‘rb‘) 13 date = pickle.loads(f.read())#---->date = pickle.load(f) 14 print(type(date["age"])) 15 print(date["age"])
shelve模塊:
相對於pickle模塊更簡單,只有一個open函數;
返回類似於字典的對象;
可讀可寫;
key必須為字符串;
value是python可支持的所有類型
json模塊、pickle模塊(序列化)shelve模塊