1. 程式人生 > >json模塊、pickle模塊(序列化)shelve模塊

json模塊、pickle模塊(序列化)shelve模塊

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)
5 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"])
View Code

shelve模塊:

  相對於pickle模塊更簡單,只有一個open函數;

  返回類似於字典的對象;

  可讀可寫;

  key必須為字符串;

  value是python可支持的所有類型

json模塊、pickle模塊(序列化)shelve模塊