一、前言
1. 現實需求
每種編程語言都有各自的數據類型,其中面向對象的編程語言還允許開發者自定義數據類型(如:自定義類),Python也是一樣。很多時候我們會有這樣的需求:
2.數據格式
如果要將一個系統內的數據通過網絡傳輸給其它系統或客戶端,我們通常都需要先把這些數據轉化為字符串或字節串,而且需要規定一種統一的數據格式才能讓數據接收端正確解析并理解這些數據的含義。XML 是早期被廣泛使用的數據交換格式,在早期的系統集成論文中經常可以看到它的身影;如今大家使用更多的數據交換格式是JSON(JavaScript Object Notation),它是一種輕量級的數據交換格式。JSON相對于XML而言,更加加單、易于閱讀和編寫,同時也易于機器解析和生成。除此之外,我們也可以自定義內部使用的數據交換格式。
如果是想把數據持久化到本地磁盤,這部分數據通常只是供系統內部使用,因此數據轉換協議以及轉換后的數據格式也就不要求是標準、統一的,只要本系統內部能夠正確識別即可。但是,系統內部的轉換協議通常會隨著編程語言版本的升級而發生變化(改進算法、提高效率),因此通常會涉及轉換協議與編程語言的版本兼容問題,下面要時候的pickle協議就是這樣一個例子。
3. 序列化/反序列化
將對象轉換為可通過網絡傳輸或可以存儲到本地磁盤的數據格式(如:XML、JSON或特定格式的字節串)的過程稱為序列化;反之,則稱為反序列化。
4.相關模塊
本節要介紹的就是Python內置的幾個用于進行數據序列化的模塊:
| 模塊名稱 | 描述 | 提供的api |
|---|---|---|
| json | 用于實現Python數據類型與通用(json)字符串之間的轉換 | dumps()、dump()、loads()、load() |
| pickle | 用于實現Python數據類型與Python特定二進制格式之間的轉換 | dumps()、dump()、loads()、load() |
| shelve | 專門用于將Python數據類型的持久化到磁盤,shelf是一個類似dict的對象,操作十分便捷 | open() |
二、json模塊
大部分編程語言都會提供處理json數據的接口,Python 2.6開始加入了json模塊,且把它作為一個內置模塊提供,無需下載即可使用。
1. 序列化與反序列化
Python的JSON模塊 序列化與反序列化的過程分別叫做:encoding 和 decoding。
json模塊提供了以下兩個方法來進行序列化和反序列化操作:
# 序列化:將Python對象轉換成json字符串dumps(obj, skipkeys=False, ensure_ascii=True, check_circular=True, allow_nan=True, cls=None, indent=None, separators=None, default=None, sort_keys=False, **kw)# 反序列化:將json字符串轉換成Python對象loads(s, encoding=None, cls=None, object_hook=None, parse_float=None, parse_int=None, parse_constant=None, object_pairs_hook=None, **kw)
除此之外,json模塊還提供了兩個額外的方法允許我們直接將序列化后得到的json數據保存到文件中,以及直接讀取文件中的json數據進行反序列化操作:
# 序列化:將Python對象轉換成json字符串并存儲到文件中dump(obj, fp, skipkeys=False, ensure_ascii=True, check_circular=True, allow_nan=True, cls=None, indent=None, indent=None, separators=None, default=None, sort_keys=False, **kw)# 反序列化:讀取指定文件中的json字符串并轉換成Python對象load(fp, cls=None, object_hook=None, parse_float=None, parse_int=None, parse_constant=None, object_pairs_hook=None, **kw)
2. JSON與Python之間數據類型對應關系
Python轉JSON
| Python | JSON |
|---|---|
| dict | Object |
| list, tuple | array |
| str | string |
| int, float, int- & float-derived Enums | numbers |
| True | true |
| False | false |
| None | null |
JSON轉Python
| JSON | Python |
|---|---|
| object | dict |
| array | list |
| string | str |
| number(int) | int |
| number(real) | float |
| true | True |
| false | False |
| null | None |
說明:
3. 實例:內置數據類型序列化/反序列化
序列化
# 序列化>>> json.dumps({'a':'str', 'c': True, 'e': 10, 'b': 11.1, 'd': None, 'f': [1, 2, 3], 'g':(4, 5, 6)})'{"a": "str", "c": true, "b": 11.1, "e": 10, "d": null, "g": [4, 5, 6], "f": [1, 2, 3]}'sort_keys參數: 表示序列化時是否對dict的key進行排序(dict默認是無序的)
# 序列化并對key進行排序>>> json.dumps({'a':'str', 'c': True, 'e': 10, 'b': 11.1, 'd': None, 'f': [1, 2, 3], 'g':(4, 5, 6)}, sort_keys=True)'{"a": "str", "b": 11.1, "c": true, "d": null, "e": 10, "f": [1, 2, 3], "g": [4, 5, 6]}'indent參數: 表示縮進的意思,它可以使得數據存儲的格式變得更加優雅、可讀性更強;如果indent是一個非負整數或字符串,則JSON array元素和object成員將會被以相應的縮進級別進行打印輸出;如果indent是0或負數或空字符串,則將只會插入換行,不會有縮進。
# 序列化并對key進行排序及格式化輸出>>> print(json.dumps({'a':'str', 'c': True, 'e': 10, 'b': 11.1, 'd': None, 'f': [1, 2, 3], 'g':(4, 5, 6)}, sort_keys=True, indent=4)) { "a": "str", "b": 11.1, "c": true, "d": null, "e": 10, "f": [ 1, 2, 3 ], "g": [ 4, 5, 6 ]}separators參數: 盡管indent參數可以使得數據存儲的格式變得更加優雅、可讀性更強,但是那是通過添加一些冗余的空白字符進行填充的。當json被用于網絡數據通信時,應該盡可能的減少無用的數據傳輸,這樣可以節省貸款并加快數據傳輸速度。json模塊序列化Python對象后得到的json字符串中的','號和':'號分隔符后默認都會附加一個空白字符,我們可以通過separators參數重新指定分隔符,從而去除無用的空白字符;
>>> json.dumps({'a':'str', 'c': True, 'e': 10, 'b': 11.1, 'd': None, 'f': [1, 2, 3], 'g':(4, 5, 6)})'{"a": "str", "c": true, "b": 11.1, "e": 10, "d": null, "g": [4, 5, 6], "f": [1, 2, 3]}'>>> json.dumps({'a':'str', 'c': True, 'e': 10, 'b': 11.1, 'd': None, 'f': [1, 2, 3], 'g':(4, 5, 6)}, separators=(',',':'))'{"a":"str","c":true,"b":11.1,"e":10,"d":null,"g":[4,5,6],"f":[1,2,3]}'反序列化
# 反序列化>>> json.loads('{"a": "str", "c": true, "b": 11.1, "e": 10, "d": null, "g": [4, 5, 6], "f": [1, 2, 3]}'){'c': True, 'e': 10, 'a': 'str', 'g': [4, 5, 6], 'd': None, 'f': [1, 2, 3], 'b': 11.1}>>> json.loads('{"a":"str","c":true,"b":11.1,"e":10,"d":null,"g":[4,5,6],"f":[1,2,3]}'){'c': True, 'e': 10, 'a': 'str', 'g': [4, 5, 6], 'd': None, 'f': [1, 2, 3], 'b': 11.1}dump()與load()函數示例
# 序列化到文件中>>> with open('test.json', 'w') as fp:... json.dump({'a':'str中國', 'c': True, 'e': 10, 'b': 11.1, 'd': None, 'f': [1, 2, 3], 'g':(4, 5, 6)}, fp, indent=4)# 反序列化文件中的內容>>> with open('test.json', 'r') as fp:... json.load(fp){'e': 10, 'g': [4, 5, 6], 'b': 11.1, 'c': True, 'd': None, 'a': 'str中國', 'f': [1, 2, 3]}需要說明的是: 如果試圖使用相同的fp重復調用dump()函數去序列化多個對象(或序列化同一個對象多次),將會產生一個無效的JSON文件,也就是說對于一個fp只能調用一次dump()。
4. 實例:自定義數據類型的序列化/反序列化
Python是面向對象的編程語言,我們可以自定義需要的數據類型;實際工作中,我們常常會用到自定義數據類型的序列化與反序列化操作。要實現自定義數據類型的序列化與反序列化有兩種方式:
首先來自定義一個數據類型
class Student(object): def __init__(self, name, age, sno): self.name = name self.age = age self.sno = sno def __repr__(self): return 'Student [name: %s, age: %d, sno: %d]' % (self.name, self.age, self.sno)
直接調用dumps()方法會引發TypeError錯誤:
>>> stu = Student('Tom', 19, 1)>>> print(stu)Student [name: Tom, age: 19, sno: 1]>>>>>> json.dumps(stu)...TypeError: Student [name: Tom, age: 19, sno: 1] is not JSON serializable上面的異常信息中指出:stu對象不可以被序列化為JSON個數的數據。那么我們分別通過“編寫轉換函數” 和 “繼承JSONEncoder和JSONDecoder類” 來實現對這個自定義數據類型的JSON序列化和反序列化。
方法1:編寫轉換函數
那么這個轉換函數要完成哪兩個數據類型之間的轉換呢? 從上面列出的JSON與Python數據類型的對應表中可知,JSON中的object對應的是Python中的dict,因此要對Python中的自定義數據類型的對象進行序列化,就需要先把這個對象轉換成json模塊可以直接進行序列化dict類型。由此可知,這個轉換函數是要完成的是Python對象(不是JSON對象)與dict之間的相互轉換,且序列化時轉換過程是“Python對象 --> dict --> JSON object”,反序列化的過程是“JSON object -> dict --> Python對象”。所以,我們需要編寫兩個轉換函數來分別實現序列化和反序列化時的轉換過程。
def obj2dict(obj): d = {} d['__class__'] = obj.__class__.__name__ d['__module__'] = obj.__module__ d.update(obj.__dict__) return ddef dict2obj(d): if '__class__' in d: class_name = d.pop('__class__') module_name = d.pop('__module__') module = __import__(module_name) class_ = getattr(module, class_name) args = dict((key.encode('ascii'), value) for key, value in d.items()) instance = class_(**args) else: instance = d return instance繼承JSONEncoder實現反序列化時還有一個額外的作用,就是可以通過iterencode()方法把一個很大的數據對象分多次進行序列化,這對于網絡傳輸、磁盤持久化等情景非常有用。
>>> for chunk in MyJSONEncoder().iterencode(stu):... print(chunk)...{"__class__":"Student","name":"Tom","__module__":"__main__","sno":1,"age":19}大數據對象序列化網絡傳輸偽代碼:
for chunk in JSONEncoder().iterencode(bigobject): mysocket.write(chunk)
序列化測試:
>>> import json>>> obj2dict(stu){'sno': 1, '__module__': '__main__', 'age': 19, '__class__': 'Student', 'name': 'Tom'}>>> json.dumps(obj2dict(stu))'{"sno": 1, "__module__": "__main__", "age": 19, "__class__": "Student", "name": "Tom"}'>>> json.dumps(stu, default=obj2dict)'{"sno": 1, "__module__": "__main__", "age": 19, "__class__": "Student", "name": "Tom"}'json.dumps(stu, default=obj2dict) 等價于 json.dumps(obj2dict(stu))
反序列化測試:
>>> json.loads('{"sno": 1, "__module__": "__main__", "age": 19, "__class__": "Student", "name": "Tom"}'){u'sno': 1, u'__module__': u'__main__', u'age': 19, u'name': u'Tom', u'__class__': u'Student'}>>> dict2obj(json.loads('{"sno": 1, "__module__": "__main__", "age": 19, "__class__": "Student", "name": "Tom"}'))Student [name: Tom, age: 19, sno: 1]>>> json.loads('{"sno": 1, "__module__": "__main__", "age": 19, "__class__": "Student", "name": "Tom"}', object_hook=dict2obj)Student [name: Tom, age: 19, sno: 1]json.loads(JSON_STR, object_hook=dict2obj) 等價于 dict2obj(json.loads(JSON_STR))
方法2:繼承JSONEncoder和JSONDecoder實現子類
import jsonclass MyJSONEncoder(json.JSONEncoder): def default(self, obj): d = {} d['__class__'] = obj.__class__.__name__ d['__module__'] = obj.__module__ d.update(obj.__dict__) return dclass MyJSONDecoder(json.JSONDecoder): def __init__(self): json.JSONDecoder.__init__(self, object_hook=self.dict2obj) def dict2obj(self, d): if '__class__' in d: class_name = d.pop('__class__') module_name = d.pop('__module__') module = __import__(module_name) class_ = getattr(module, class_name) args = dict((key.encode('ascii'), value) for key, value in d.items()) instance = class_(**args) else: instance = d return instance序列化測試:
>>> stu = Student('Tom', 19, 1)# 方式一:直接調用子類MyJSONEncoder的encode()方法進行序列化>>> MyJSONEncoder().encode(stu)'{"__class__": "Student", "__module__": "__main__", "name": "Tom", "age": 19, "sno": 1}'>>> MyJSONEncoder(separators=(',', ':')).encode(stu)'{"__class__":"Student","__module__":"__main__","name":"Tom","age":19,"sno":1}'# 方式二:將子類MyJSONEncoder作為cls參數的值傳遞給json.dumps()函數>>> json.dumps(stu, cls=MyJSONEncoder)'{"__class__": "Student", "__module__": "__main__", "name": "Tom", "age": 19, "sno": 1}'>>> json.dumps(stu, cls=MyJSONEncoder, separators=(',', ':'))'{"__class__":"Student","__module__":"__main__","name":"Tom","age":19,"sno":1}'反序列化測試:
>>> MyJSONDecoder().decode('{"sno": 1, "__module__": "__main__", "age": 19, "__class__": "Student", "name": "Tom"}')Student [name: Tom, age: 19, sno: 1]說明: 經過測試發現MyJSONDecoder().decode(JSON_STR) 和 json.loads(JSON_STR, object_hook=dict2obj) 只能在Python 2.7上正確執行,在Python 3.5上無法正確執行;而 json.loads(JSON_STR, cls=MyJSONDecoder) 無論在Python 2.7還是在Python 3.5上都無法正確執行。這說明json模塊對于自定義數據類型的反序列化支持還是比較有限的,但是我們也可以通過json.loads(JSON_STR)函數,不指定cls參數來得到一個dict對象,然后自己完成dict到object的轉換。
三、pickle模塊
pickle模塊實現了用于對Python對象結構進行 序列化 和 反序列化 的二進制協議,與json模塊不同的是pickle模塊序列化和反序列化的過程分別叫做 pickling 和 unpickling:
1. pickle模塊與json模塊對比
2. pickle模塊使用的數據流格式
上面提到,pickle使用的數據格式是特定于Python的。這使得它不受諸如JSON或XDR的外部標準限值,但是這也意味著非Python程序可能無法重建pickled Python對象。默認情況下,pickle數據格式使用相對緊湊的二進制表示。如果需要最佳大小特征,可以有效的壓縮pickled數據。pickletools模塊包含可以用于對pickle生成的數據流進行分析的工具。目前有5種不同的協議可以用于pickle。使用的協議越高,就需要更新的Python版本去讀取pickle產生的數據:
說明: Python 2.x中默認使用的是協議v0,如果協議指定為賦值或HIGHEST_PROTOCOL,將使用當前可用的最高協議版本;Python 3.x中默認使用的是協議v3,它兼容其他Python 3版本,但是不兼容Python 2。
注意: 序列化(Serialization)是一個比持久化(Persistence)更加原始的概念;雖然pickle可以讀寫文件對象,但是它不處理持久化對象的命名問題,也不處理對持久化對象的并發訪問問題(甚至更復雜的問題)。pickle模塊可以將復雜對象轉換為字節流,并且可以將字節流轉換為具有相同內部結構的對象?;蛟S最可能對這些字節流做的事情是將它們寫入文件,但是也可以對它們進行網絡傳輸或將它們存儲在數據庫中。shelve模塊提供了一個簡單的接口用于在DBM風格的數據庫文件上對對象進行pickle和unpickle操作。
3. pickle模塊提供的相關函數
pickle模塊提供的幾個序列化/反序列化的函數與json模塊基本一致:
# 將指定的Python對象通過pickle序列化作為bytes對象返回,而不是將其寫入文件dumps(obj, protocol=None, *, fix_imports=True)# 將通過pickle序列化后得到的字節對象進行反序列化,轉換為Python對象并返回loads(bytes_object, *, fix_imports=True, encoding="ASCII", errors="strict")# 將指定的Python對象通過pickle序列化后寫入打開的文件對象中,等價于`Pickler(file, protocol).dump(obj)`dump(obj, file, protocol=None, *, fix_imports=True)# 從打開的文件對象中讀取pickled對象表現形式并返回通過pickle反序列化后得到的Python對象load(file, *, fix_imports=True, encoding="ASCII", errors="strict")
說明: 上面這幾個方法參數中,*號后面的參數都是Python 3.x新增的,目的是為了兼容Python 2.x,具體用法請參看官方文檔。
4. 實例:內置數據類型的序列化/反序列化
Python 2.x
>>> import pickle>>> >>> var_a = {'a':'str', 'c': True, 'e': 10, 'b': 11.1, 'd': None, 'f': [1, 2, 3], 'g':(4, 5, 6)}# 序列化>>> var_b = pickle.dumps(var_a)>>> var_b"(dp0/nS'a'/np1/nS'str'/np2/nsS'c'/np3/nI01/nsS'b'/np4/nF11.1/nsS'e'/np5/nI10/nsS'd'/np6/nNsS'g'/np7/n(I4/nI5/nI6/ntp8/nsS'f'/np9/n(lp10/nI1/naI2/naI3/nas."# 反序列化>>> var_c = pickle.loads(var_b)>>> var_c{'a': 'str', 'c': True, 'b': 11.1, 'e': 10, 'd': None, 'g': (4, 5, 6), 'f': [1, 2, 3]}Python 3.x
>>> import pickle>>>>>> var_a = {'a':'str', 'c': True, 'e': 10, 'b': 11.1, 'd': None, 'f': [1, 2, 3], 'g':(4, 5, 6)}# 序列化>>> var_b = pickle.dumps(var_a)>>> var_bb'/x80/x03}q/x00(X/x01/x00/x00/x00eq/x01K/nX/x01/x00/x00/x00aq/x02X/x03/x00/x00/x00strq/x03X/x01/x00/x00/x00fq/x04]q/x05(K/x01K/x02K/x03eX/x01/x00/x00/x00gq/x06K/x04K/x05K/x06/x87q/x07X/x01/x00/x00/x00bq/x08G@&333333X/x01/x00/x00/x00cq/t/x88X/x01/x00/x00/x00dq/nNu.'# 反序列化>>> var_c = pickle.loads(var_b)>>> var_c{'e': 10, 'a': 'str', 'f': [1, 2, 3], 'g': (4, 5, 6), 'b': 11.1, 'c': True, 'd': None}dump()與load()
>>> import pickle>>>>>> var_a = {'a':'str', 'c': True, 'e': 10, 'b': 11.1, 'd': None, 'f': [1, 2, 3], 'g':(4, 5, 6)}# 持久化到文件>>> with open('pickle.txt', 'wb') as f:... pickle.dump(var_a, f)...# 從文件中讀取數據>>> with open('pickle.txt', 'rb') as f:... var_b = pickle.load(f)...>>> var_b{'e': 10, 'a': 'str', 'f': [1, 2, 3], 'g': (4, 5, 6), 'b': 11.1, 'c': True, 'd': None}>>>
說明:
5. 實例:自定義數據類型的序列化/反序列化
首先來自定義一個數據類型:
class Student(object): def __init__(self, name, age, sno): self.name = name self.age = age self.sno = sno def __repr__(self): return 'Student [name: %s, age: %d, sno: %d]' % (self.name, self.age, self.sno)
pickle模塊可以直接對自定數據類型進行序列化/反序列化操作,無需編寫額外的處理函數或類。
>>> stu = Student('Tom', 19, 1)>>> print(stu)Student [name: Tom, age: 19, sno: 1]# 序列化>>> var_b = pickle.dumps(stu)>>> var_bb'/x80/x03c__main__/nStudent/nq/x00)/x81q/x01}q/x02(X/x04/x00/x00/x00nameq/x03X/x03/x00/x00/x00Tomq/x04X/x03/x00/x00/x00ageq/x05K/x13X/x03/x00/x00/x00snoq/x06K/x01ub.'# 反序列化>>> var_c = pickle.loads(var_b)>>> var_cStudent [name: Tom, age: 19, sno: 1]# 持久化到文件>>> with open('pickle.txt', 'wb') as f:... pickle.dump(stu, f)...# 從文件總讀取數據>>> with open('pickle.txt', 'rb') as f:... pickle.load(f)...Student [name: Tom, age: 19, sno: 1]四、shelve模塊
shelve是一個簡單的數據存儲方案,類似key-value數據庫,可以很方便的保存python對象,其內部是通過pickle協議來實現數據序列化。shelve只有一個open()函數,這個函數用于打開指定的文件(一個持久的字典),然后返回一個shelf對象。shelf是一種持久的、類似字典的對象。它與“dbm”的不同之處在于,其values值可以是任意基本Python對象--pickle模塊可以處理的任何數據。這包括大多數類實例、遞歸數據類型和包含很多共享子對象的對象。keys還是普通的字符串。
open(filename, flag='c', protocol=None, writeback=False)
flag 參數表示打開數據存儲文件的格式,可取值與dbm.open()函數一致:
| 值 | 描述 |
|---|---|
| 'r' | 以只讀模式打開一個已經存在的數據存儲文件 |
| 'w' | 以讀寫模式打開一個已經存在的數據存儲文件 |
| 'c' | 以讀寫模式打開一個數據存儲文件,如果不存在則創建 |
| 'n' | 總是創建一個新的、空數據存儲文件,并以讀寫模式打開 |
protocol 參數表示序列化數據所使用的協議版本,默認是pickle v3;
writeback 參數表示是否開啟回寫功能。
我們可以把shelf對象當dict來使用--存儲、更改、查詢某個key對應的數據,當操作完成之后,調用shelf對象的close()函數即可。當然,也可以使用上下文管理器(with語句),避免每次都要手動調用close()方法。
實例:內置數據類型操作
# 保存數據with shelve.open('student') as db: db['name'] = 'Tom' db['age'] = 19 db['hobby'] = ['籃球', '看電影', '彈吉他'] db['other_info'] = {'sno': 1, 'addr': 'xxxx'}# 讀取數據with shelve.open('student') as db: for key,value in db.items(): print(key, ': ', value)輸出結果:
name : Tom
age : 19
hobby : ['籃球', '看電影', '彈吉他']
other_info : {'sno': 1, 'addr': 'xxxx'}
實例:自定義數據類型操作
# 自定義classclass Student(object): def __init__(self, name, age, sno): self.name = name self.age = age self.sno = sno def __repr__(self): return 'Student [name: %s, age: %d, sno: %d]' % (self.name, self.age, self.sno)# 保存數據tom = Student('Tom', 19, 1)jerry = Student('Jerry', 17, 2)with shelve.open("stu.db") as db: db['Tom'] = tom db['Jerry'] = jerry# 讀取數據with shelve.open("stu.db") as db: print(db['Tom']) print(db['Jerry'])輸出結果:
Student [name: Tom, age: 19, sno: 1]
Student [name: Jerry, age: 17, sno: 2]
五、總結
1. 對比
json模塊常用于編寫web接口,將Python數據轉換為通用的json格式傳遞給其它系統或客戶端;也可以用于將Python數據保存到本地文件中,缺點是明文保存,保密性差。另外,如果需要保存費內置數據類型需要編寫額外的轉換函數或自定義類。
pickle模塊和shelve模塊由于使用其特有的序列化協議,其序列化之后的數據只能被Python識別,因此只能用于Python系統內部。另外,Python 2.x 和 Python
3.x 默認使用的序列化協議也不同,如果需要互相兼容需要在序列化時通過protocol參數指定協議版本。除了上面這些缺點外,pickle模塊和shelve模塊相對于json模塊的優點在于對于自定義數據類型可以直接序列化和反序列化,不需要編寫額外的轉換函數或類。
shelve模塊可以看做是pickle模塊的升級版,因為shelve使用的就是pickle的序列化協議,但是shelve比pickle提供的操作方式更加簡單、方便。shelve模塊相對于其它兩個模塊在將Python數據持久化到本地磁盤時有一個很明顯的優點就是,它允許我們可以像操作dict一樣操作被序列化的數據,而不必一次性的保存或讀取所有數據。
2. 建議
3. 附錄
| 要實現的功能 | 可以使用的api |
|---|---|
| 將Python數據類型轉換為(json)字符串 | json.dumps() |
| 將json字符串轉換為Python數據類型 | json.loads() |
| 將Python數據類型以json形式保存到本地磁盤 | json.dump() |
| 將本地磁盤文件中的json數據轉換為Python數據類型 | json.load() |
| 將Python數據類型轉換為Python特定的二進制格式 | pickle.dumps() |
| 將Python特定的的二進制格式數據轉換為Python數據類型 | pickle.loads() |
| 將Python數據類型以Python特定的二進制格式保存到本地磁盤 | pickle.dump() |
| 將本地磁盤文件中的Python特定的二進制格式數據轉換為Python數據類型 | pickle.load() |
| 以類型dict的形式將Python數據類型保存到本地磁盤或讀取本地磁盤數據并轉換為數據類型 | shelve.open() |
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。
新聞熱點
疑難解答
圖片精選