days-json和pickle序列化
阿新 • • 發佈:2017-07-21
pick 編碼 bytes 數據交換格式 rip dict 文件 介質 打開文件 一.json模塊
序列化:把一個對象的形態改變一下,使他能夠存放在文件中,或者在網絡上傳輸,序列化也叫持久化,是把對象存儲到永久介質中,這樣就不會因為掉電而丟失。
JSON (JavaScript Object Notation) 是一種輕量級的數據交換格式,json用於字符串和python的數據類型進行轉換,json模塊提供了四個功能:dumps、dump、loads、load
json.dumps和json.loads實例:
1 #!/usr/bin/python3 2 import json 3 data = {‘name‘:‘JieSen‘,‘height‘:175,‘weight‘:‘68KG輸出: dumps到字符串: {"name": "JieSen", "height": 175, "weight": "68KG"} 類型: <class ‘str‘> loads回來: {‘name‘: ‘JieSen‘, ‘height‘: 175, ‘weight‘: ‘68KG‘} 類型: <class ‘dict‘> 如果處理的是文件,而不是字符串,可以使用json.dump和json.load進行編碼和解碼。例如:‘} 4 #dumps到字符串 5 json_str = json.dumps(data) 6 print(‘dumps到字符串:‘,json_str,‘類型:‘,type(json_str)) 7 #loads回來 8 json_dict = json.loads(json_str) 9 print(‘loads回來:‘,json_dict,‘類型:‘,type(json_dict))
1 #!/usr/bin/python3 2 import json 3 with open(‘data_json.txt‘,‘w+‘,encoding=‘utf-8‘) as f: 4 json.dump(data,f) 5 with open(‘data_json.txt‘,‘r‘) as f: 6 data_r = json.load(f) 7 print(data_r)輸出: {‘name‘:‘JieSen‘,‘height‘:175,‘weight‘:‘68KG‘} 二.pickle模塊 pickle序列化對象是一個二進制字節,以便將一個文件存儲保存到文件或者通過網絡傳輸。 pickle.dump和pickle.load實例:
1 #!/use/bin/python3 2 import pickle 3 data = {‘k1‘:1,‘k2‘:2} 4 #以二進制方式打開一個文件並將數據dump保存到文件裏面 5 with open(‘pickle_data.txt‘,‘wb‘) as f: 6 pickle.dump(data,f) 7 #以二進制讀取方式打開文件並load加載 8 with open(‘pickle_data.txt‘,‘rb‘) as f: 9 fb = pickle.load(f) 10 print(fb)
輸出:
{‘k1‘: 1, ‘k2‘: 2}
如果處理的不是文件,可以使用pickle.dumps和pickle.loads,例如:
data = {‘name‘:‘JieSen‘,‘height‘:175,‘weight‘:‘68KG‘} #轉換為一個字節流對象 pickle_byte = pickle.dumps(data) print(pickle_byte,‘格式:‘,type(pickle_byte)) #從字節流中恢復對象 pickle_dict = pickle.loads(pickle_byte) print(pickle_dict,‘格式:‘,type(pickle_dict))
輸出:
b‘\x80\x03}q\x00(X\x04\x00\x00\x00nameq\x01X\x06\x00\x00\x00JieSenq\x02X\x06\x00\x00\x00heightq\x03K\xafX\x06\x00\x00\x00weightq\x04X\x04\x00\x00\x0068KGq\x05u.‘ 格式: <class ‘bytes‘>
{‘name‘: ‘JieSen‘, ‘height‘: 175, ‘weight‘: ‘68KG‘} 格式: <class ‘dict‘>
總結:
1.pickle序列化的是字節,而json序列化的是字符。
2.json.dump,json.load和pickle.dump,pickle.road處理的都是文件。
days-json和pickle序列化