1. 程式人生 > >days-json和pickle序列化

days-json和pickle序列化

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
} 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))
輸出: dumps到字符串: {"name": "JieSen", "height": 175, "weight": "68KG"} 類型: <class ‘str‘> loads回來: {‘name‘: ‘JieSen‘, ‘height‘: 175, ‘weight‘: ‘68KG‘} 類型: <class ‘dict‘> 如果處理的是文件,而不是字符串,可以使用json.dump和json.load進行編碼和解碼。例如:
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序列化