日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

常用模块(数据序列化 json、pickle、shelve)

發布時間:2024/10/12 编程问答 36 豆豆
生活随笔 收集整理的這篇文章主要介紹了 常用模块(数据序列化 json、pickle、shelve) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

本節內容


  • 前言
  • json模塊
  • pickle模塊
  • shelve模塊
  • 總結
  • 一、前言


    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數據類型的數據持久化到磁盤,shelve是一個類似dict的對象,操作十分便捷open()

    二、json模塊


    大部分編程語言都會提供處理json數據的接口,Python 2.6開始加入了json模塊,且把它作為一個內置模塊提供,無需下載即可使用。

    1. 序列化與反序列化

    Python的JSON模塊 序列化與反序列化的過程分別叫做:encoding 和 decoding。

    • encoding:?把Python對象轉換成JSON字符串
    • decoding:?把JSON字符串轉換成python對象

    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, 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

    PythonJSON
    dictObject
    list, tuplearray
    strstring
    int, float, int- & float-derived Enumsnumbers
    Truetrue
    Falsefalse
    Nonenull

    JSON轉Python

    JSONPython
    objectdict
    arraylist
    stringstr
    number(int)int
    number(real)float
    trueTrue
    falseFalse
    nullNone

    說明:

    • Python dict中的非字符串key被轉換成JSON字符串時都會被轉換為小寫字符串;
    • Python中的tuple,在序列化時會被轉換為array,但是反序列化時,array會被轉化為list;
    • 由以上兩點可知,當Python對象中包含tuple數據或者包含dict,且dict中存在非字符串的key時,反序列化后得到的結果與原來的Python對象是不一致的;
    • 對于Python內置的數據類型(如:str, unicode, int, float, bool, None, list, tuple, dict)json模塊可以直接進行序列化/反序列化處理;對于自定義類的對象進行序列化和反序列化時,需要我們自己定義一個方法來完成定義object和dict之間進行轉化。

    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參數重新指定分隔符,從而去除無用的空白字符;

    • 該參數的值應該是一個tuple(item_separator, key_separator)
    • 如果indent是None,其默認值為(', ', ': ')
    • 如果indent不為None,則默認值為(',', ': ')
    • 我們可以通過為separator賦值為(',', ':')來消除空白字符
    >>> 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]}'

    ensure_ascii參數:?當該參數的值為True(默認值)時,輸出中的所有非ASCII字符(比如中文)都會被轉義成'\uXXXX'組成的序列,得到的結果是一個完全由ASCII字符組成的str實例。如果我們想得到一個人類可讀的輸出結果,需要把ensure_ascii參數的值設置為False。

    >>> stu={"name": "小明", "age" : 16} >>> stu_json = json.dumps(stu) >>> print(stu_json) '{"name": "\u5c0f\u660e", "age": 16}' >>> stu_json01 = json.dumps(stu, ensure_ascii=False) >>> print(stu_json01) '{"name": "小明", "age": 16}'

    說明:?實際上'\uXXXX'是Unicode字符對應的內存編碼值,該內存編碼名稱為"unicode-escape",我們可以通過unicodestr.encode('unicode-escape')和decode('unicode-escape')來完成Unicode字符串與Unicode內存編碼序列進行相互轉換,如下所示:

    >>> str1 = "hello 中國" >>> str2 = str1.encode("unicode_escape") >>> print(str2) b'hello \\u4e2d\\u56fd' >>> str3 = str2.decode("unicode_escape") >>> print(str3) hello 中國

    注意str2是字節串,不是字符串,因此\u前面需要再加一個反斜線做轉義。我們把str2轉換成字符串就是我們熟悉的格式了:

    >>> str4=str2.decode("utf-8") >>> print(str4) hello \u4e2d\u56fd >>>

    反序列化

    # 反序列化 >>> 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是面向對象的編程語言,我們可以自定義需要的數據類型;實際工作中,我們常常會用到自定義數據類型的序列化與反序列化操作。要實現自定義數據類型的序列化與反序列化有兩種方式:

    • 通過轉換函數實現
    • 通過繼承JSONEncoder和JSONDecoder類實現

    首先來自定義一個數據類型

    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 d def 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
    序列化測試:
    >>> 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 d class 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的轉換。

    繼承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)

    三、pickle模塊


    pickle模塊實現了用于對Python對象結構進行 序列化 和 反序列化 的二進制協議,與json模塊不同的是pickle模塊序列化和反序列化的過程分別叫做 pickling 和 unpickling:

    • pickling:?是將Python對象轉換為字節流的過程;
    • unpickling:?是將字節流二進制文件或字節對象轉換回Python對象的過程;

    1. pickle模塊與json模塊對比

    • JSON是一種文本序列化格式(它輸出的是unicode文件,大多數時候會被編碼為utf-8),而pickle是一個二進制序列化格式;
    • JOSN是我們可以讀懂的數據格式,而pickle是二進制格式,我們無法讀懂;
    • JSON是與特定的編程語言或系統無關的,且它在Python生態系統之外被廣泛使用,而pickle使用的數據格式是特定于Python的;
    • 默認情況下,JSON只能表示Python內建數據類型,對于自定義數據類型需要一些額外的工作來完成;pickle可以直接表示大量的Python數據類型,包括自定數據類型(其中,許多是通過巧妙地使用Python內省功能自動實現的;復雜的情況可以通過實現specific object API來解決)

    2. pickle模塊使用的數據流格式

    上面提到,pickle使用的數據格式是特定于Python的。這使得它不受諸如JSON或XDR的外部標準限值,但是這也意味著非Python程序可能無法重建pickled Python對象。默認情況下,pickle數據格式使用相對緊湊的二進制表示。如果需要最佳大小特征,可以有效的壓縮pickled數據。pickletools模塊包含可以用于對pickle生成的數據流進行分析的工具。目前有5種不同的協議可以用于pickle。使用的協議越高,就需要更新的Python版本去讀取pickle產生的數據:

    • 協議v0是原始的“人類可讀”協議,并且向后兼容早期的Python版本;
    • 協議v1是一個舊的二進制格式,也與早期版本的Python兼容;
    • 協議v2在Python 2.3中引入,它提供更高效的pickling;
    • 協議v3是在Python 3.0添加的協議,它明確支持bytes對象,且不能被Python 2.x 進行unpickle操作;這是默認協議,也是當需要兼容其他Python 3版本時被推薦使用的協議;
    • 協議4是在Python 3.4添加的協議,它添加了對極大對象的支持,pickling更多種類的對象,以及一些數據格式的優化。

    說明:?Python 2.x中默認使用的是協議v0,如果協議指定為賦值或HIGHEST_PROTOCOL,將使用當前可用的最高協議版本;Python 3.x中默認使用的是協議v3,它兼容其他Python 3版本,但是不兼容Python 2。

    注意:?序列化(Serialization)是一個比持久化(Persistence)更加原始的概念;雖然pickle可以讀寫文件對象,但是它不處理持久化對象的命名問題,也不處理對持久化對象的并發訪問問題(甚至更復雜的問題)。pickle模塊可以將復雜對象轉換為字節流,并且可以將字節流轉換為具有相同內部結構的對象。或許最可能對這些字節流做的事情是將它們寫入文件,但是也可以對它們進行網絡傳輸或將它們存儲在數據庫中。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_b b'\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} >>>

    說明:

    • 默認情況下Python 2.x中pickled后的數據是字符串形式,需要將它轉換為字節對象才能被Python 3.x中的pickle.loads()反序列化;Python 3.x中pickling所使用的協議是v3,因此需要在調用pickle.dumps()時指定可選參數protocol為Python 2.x所支持的協議版本(0,1,2),否則pickled后的數據不能被被Python 2.x中的pickle.loads()反序列化;
    • Python 3.x中pickle.dump()和pickle.load()方法中指定的文件對象,必須以二進制模式打開,而Python 2.x中可以以二進制模式打開,也可以以文本模式打開。

    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_b b'\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_c Student [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'}

    實例:自定義數據類型操作

    # 自定義class 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) # 保存數據 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. 建議

    • 需要與外部系統交互時用json模塊;
    • 需要將少量、簡單Python數據持久化到本地磁盤文件時可以考慮用pickle模塊;
    • 需要將大量Python數據持久化到本地磁盤文件或需要一些簡單的類似數據庫的增刪改查功能時,可以考慮用shelve模塊。

    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()

    轉載于:https://www.cnblogs.com/jt925/p/10226620.html

    總結

    以上是生活随笔為你收集整理的常用模块(数据序列化 json、pickle、shelve)的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

    av黄色在线播放 | 欧美aa级| 午夜精品久久久99热福利 | 亚洲国产精品电影 | 亚洲狠狠操 | 青草草在线 | 91日本在线播放 | 超碰97在线看 | 国产精品久久久久国产精品日日 | 曰韩在线 | 久草在线中文视频 | 国产一区二区三区久久久 | 欧美视频国产视频 | 91亚色视频在线观看 | 曰韩在线 | 在线观看免费视频你懂的 | 深爱婷婷| 免费a级黄色毛片 | a精品视频 | 特及黄色片 | 人人看人人草 | 天天草综合 | 国产成人av网站 | 国产麻豆电影 | 久久久久国产精品www | 亚洲国产中文在线 | 一区二区三区免费看 | 中文字幕亚洲在线观看 | 黄色视屏av | 中文字幕文字幕一区二区 | 一区二区精品久久 | 亚洲视频axxx| 中文字幕在线资源 | 成人黄色片免费 | 碰天天操天天 | 国产亚洲精品久久久久5区 成人h电影在线观看 | 2023亚洲精品国偷拍自产在线 | 黄色a在线观看 | 欧美视频在线二区 | 日韩资源在线播放 | 久艹在线播放 | 久久国语露脸国产精品电影 | 亚洲精品系列 | 国产美女在线免费观看 | 久久久久福利视频 | 日韩免费不卡av | 91成人天堂久久成人 | 免费在线看成人av | 很黄很色很污的网站 | 亚洲综合色网站 | 欧美精彩视频在线观看 | 日本三级不卡视频 | 9ⅰ精品久久久久久久久中文字幕 | 99视频在线观看免费 | 三级黄色欧美 | 最近中文字幕免费视频 | 日本在线中文在线 | 99热精品国产一区二区在线观看 | 欧美久久影院 | av网站大全免费 | 日韩在线视频免费观看 | 九九综合在线 | 97香蕉久久国产在线观看 | 免费a v视频 | 日韩字幕在线 | 精品国产一区二区三区久久久久久 | 成年美女黄网站色大片免费看 | 精品自拍sae8—视频 | 91完整视频 | 色香蕉在线| 国产理论在线 | 亚洲黄色免费在线看 | 天天草综合网 | 国产婷婷视频在线 | 亚洲精品乱码久久久久久高潮 | 日韩精品免费一线在线观看 | 久久这里只有精品1 | 国产 日韩 在线 亚洲 字幕 中文 | 久久av中文字幕片 | 免费网站黄 | 日韩一区二区三区观看 | 91麻豆精品一区二区三区 | 国产精品va最新国产精品视频 | 日韩综合第一页 | 亚洲天堂网视频 | 99视频导航 | 一级全黄毛片 | 色天天中文 | 久久爱资源网 | 久久久久久伊人 | а中文在线天堂 | 丁香婷婷射 | 国产香蕉视频在线播放 | 五月天婷婷狠狠 | 亚洲精品网站在线 | 国产传媒中文字幕 | 日韩在线观看视频一区二区三区 | 日韩在线观看你懂得 | 天天拍天天操 | 国产操在线 | 黄色av免费看| 麻豆视传媒官网免费观看 | 国产精品黄网站在线观看 | 精品国产乱码久久久久久久 | 国产黑丝一区二区 | 夜夜操夜夜干 | 五月视频| 欧美91片| 在线视频观看亚洲 | 欧美成年黄网站色视频 | 天天操婷婷 | 久久久国产精品亚洲一区 | 91网在线| 欧美精品一区二区免费 | 欧美一区二区三区在线播放 | 国产精品久久久777 成人手机在线视频 | 日韩欧美在线视频一区二区三区 | 国产精品一区二区免费在线观看 | 特及黄色片 | 天天激情综合网 | 亚洲国产一区在线观看 | 丰满少妇一级片 | 日韩欧美xxx| 丁香久久五月 | 天天爱天天操 | 欧美久久99| 欧美久久久久久久久久久 | 九九热精品国产 | 国产伦精品一区二区三区在线 | 97香蕉视频 | 日韩视频免费 | 99精品免费久久久久久日本 | 成人久久久久久久久久 | 亚洲精品在线观看av | 国产一区二区精 | 精品国产伦一区二区三区观看方式 | 日日夜操 | www视频免费在线观看 | 五月天久久综合 | 免费观看性生活大片3 | 国产一区二区三区在线 | 麻豆国产精品一区二区三区 | 国产在线观看 | 337p欧美 | 国产精品久久久久久久久久了 | 日韩激情精品 | 国产电影一区二区三区四区 | 国产99久| 日韩av在线高清 | 中中文字幕av | 国产精品18久久久久久首页狼 | 久久综合五月天 | 欧美综合久久久 | 国产免费av一区二区三区 | 最新av在线免费观看 | 国产做爰视频 | 欧美天天综合 | 一区二区三区四区五区在线视频 | 免费在线观看黄网站 | 精品亚洲视频在线 | 成人黄色在线 | 五月天久久久久 | 亚洲乱码久久久 | 久久99免费| 免费av片在线 | 综合久久久久久久 | 在线看污网站 | 91最新视频 | 91.麻豆视频| 日韩电影在线观看中文字幕 | 夜色.com | 婷婷射五月| 91九色视频在线 | 久久国产热 | 福利久久久 | 911av视频| 夜夜躁日日躁 | 国产亚洲视频系列 | 欧美精品色| 久久影院中文字幕 | 伊人久操 | 国产午夜小视频 | 嫩草av在线 | 99久久综合狠狠综合久久 | a极黄色片| 国产精品久久久久久久久久不蜜月 | 99精品国产一区二区三区不卡 | 亚洲精品一区二区18漫画 | av成人在线网站 | 精品一区二三区 | aaa日本高清在线播放免费观看 | 一区精品久久 | 天天做天天爱天天爽综合网 | 伊人午夜| av中文字幕第一页 | 在线播放亚洲激情 | 日本久久视频 | 黄色小网站在线观看 | 国产精品第二十页 | 伊人久久在线观看 | 国产精品免费观看视频 | 精品国产一区二区三区在线 | 天天色成人 | 免费久久精品视频 | 日本婷婷色 | 国产五十路毛片 | 久草视频在线免费 | 中文字幕精品一区二区精品 | 日批在线观看 | 国产一区二区在线观看免费 | 久久久久成人精品 | 国产免费观看av | www欧美日韩 | 成人三级网站在线观看 | 天堂黄色片| 在线观看片 | 中文字幕在线视频第一页 | bbbbb女女女女女bbbbb国产 | 国产色在线视频 | 中文字幕色婷婷在线视频 | 国产二区视频在线观看 | 国产一区二区不卡视频 | 九九热在线观看 | 欧美日韩在线精品一区二区 | 欧美一级日韩免费不卡 | 国产成人精品久久久 | 九九热在线观看 | 毛片网在线观看 | 国产又粗又硬又爽视频 | 99久久精品国产亚洲 | 国产成人av综合色 | 亚洲伦理中文字幕 | 一本一本久久a久久精品综合妖精 | 91日韩精品视频 | 色婷婷导航 | 久久国产精品一国产精品 | 免费观看日韩av | 日本精油按摩3 | 日韩欧美xxx| 激情综合婷婷 | 亚洲一级电影在线观看 | 国产成人精品网站 | 亚洲国产偷 | 成年人在线免费看视频 | 99看视频在线观看 | 国外成人在线视频网站 | 夜夜澡人模人人添人人看 | 欧美亚洲久久 | 色综合久久网 | 日韩区欧美久久久无人区 | 九九免费在线视频 | 欧美久草视频 | 成人性生交大片免费看中文网站 | 免费网站黄 | 久久久久久久久久久久电影 | 欧美精品一区二区在线观看 | 久久精品亚洲综合专区 | 伊人亚洲综合 | 国产精品国产自产拍高清av | 色综合亚洲精品激情狠狠 | 日韩欧美视频在线观看免费 | 天操夜夜操 | 91重口视频 | 午夜在线看片 | 一本一本久久a久久精品综合 | 日日天天干 | 五月激情久久 | 亚州精品天堂中文字幕 | 黄色视屏在线免费观看 | 97在线免费视频 | 免费的国产精品 | ,午夜性刺激免费看视频 | 嫩小bbbb摸bbb摸bbb | 久草在线费播放视频 | jizz999| 手机成人av | 成人小视频免费在线观看 | 亚洲国产精品99久久久久久久久 | 99久久久久| 国产欧美在线一区 | 久久免费影院 | 激情欧美一区二区免费视频 | 欧美成人影音 | 国产视频在 | 91在线观看视频网站 | 日韩视频二区 | 久久在现 | 亚洲欧美日韩在线一区二区 | 日本性生活免费看 | 日韩精品久久久 | 在线观看视频一区二区三区 | 国产成人精品免高潮在线观看 | 国产精品白丝av | 婷婷六月在线 | 在线黄网站 | 色视频网站在线 | 激情五月综合 | 丁香五婷| 亚洲精品乱码久久久久久 | 久操视频在线播放 | 91av在线电影 | 久久99热国产 | 免费电影一区二区三区 | 一本之道乱码区 | 91精品入口| 国产精品视频大全 | 日本中文字幕久久 | 国产视频午夜 | 国产专区一 | 91精品人成在线观看 | 日韩一区二区三区高清在线观看 | 亚洲精品视频免费看 | 婷婷福利影院 | 久久精品1区 | 亚洲精品免费在线观看视频 | www.天堂av | 日韩一区正在播放 | 亚州精品在线视频 | 久久精品99国产精品酒店日本 | 91日韩国产| 女人高潮一级片 | av7777777| 国产一区二区在线观看免费 | 黄色毛片观看 | 精品久久久免费视频 | 日韩一二区在线 | 婷婷伊人五月 | 国产精品大尺度 | 亚洲国产精品一区二区久久,亚洲午夜 | 婷婷综合国产 | 麻豆手机在线 | 在线免费观看黄网站 | 97免费在线视频 | 九九有精品 | 久久婷婷色综合 | 91视频传媒 | 欧美精品久久久久久久免费 | 粉嫩av一区二区三区四区 | 色婷婷www | 天天射天天舔天天干 | 波多野结衣在线播放一区 | 国产精品高清在线 | 国产成人免费在线观看 | 人人澡视频 | 99久视频| 99久久精品久久亚洲精品 | 正在播放五月婷婷狠狠干 | 久久久久国产精品一区 | 亚洲精品字幕在线 | 2020天天干夜夜爽 | 美女视频久久久 | 国产色拍拍拍拍在线精品 | 性色av香蕉一区二区 | 精品国产亚洲一区二区麻豆 | 九七视频在线观看 | 精品美女久久久久 | www国产亚洲精品久久网站 | 亚洲综合网站在线观看 | 婷婷色网视频在线播放 | 狠狠干综合 | 色多多污污在线观看 | 久久99久久精品国产 | 国产亚洲欧美日韩高清 | 国产做aⅴ在线视频播放 | 十八岁以下禁止观看的1000个网站 | 国产在线91在线电影 | 怡春院av| 久久99精品一区二区三区三区 | www色综合 | 国产精品人人做人人爽人人添 | 激情视频一区二区 | 欧美色图亚洲图片 | 成人一区在线观看 | 久久国产一二区 | 国产精品久久久久久久久久久久午夜 | 欧美在线不卡一区 | 日韩精品视频免费在线观看 | 91色蜜桃| 在线欧美日韩 | 国产精品久久久久久久久久久免费看 | 久久免费高清 | 国产精品99久久久久久小说 | 在线 视频 亚洲 | 狠狠狠色狠狠色综合 | 欧美精品一区二区三区一线天视频 | 久久午夜国产 | av资源在线看 | 午夜性福利| 欧美精品国产综合久久 | 欧美成a人片在线观看久 | 免费观看高清 | 久二影院| 久久久久欧美精品 | 国产高清在线视频 | 中文字幕视频免费观看 | 免费网站看v片在线a | 成人黄色片免费看 | www黄色av | 在线 视频 一区二区 | 99精彩视频 | av五月婷婷 | 一性一交视频 | 最新国产中文字幕 | 美女视频永久黄网站免费观看国产 | 欧美污在线观看 | 天天综合网久久 | 成人在线观看免费视频 | 人人爱人人射 | 日本三级不卡视频 | 欧美色噜噜噜 | 成全在线视频免费观看 | 色偷偷男人的天堂av | 色 免费观看 | 国产精品中文久久久久久久 | 欧美一级片免费 | 中文字幕国产精品一区二区 | 免费男女羞羞的视频网站中文字幕 | 中文字幕高清免费日韩视频在线 | 亚洲激情视频在线观看 | 日韩91在线| 国产高清永久免费 | 久久精品国产免费看久久精品 | 婷婷av色综合 | 狠狠色婷婷丁香六月 | 国产青青青| 最近乱久中文字幕 | 日韩最新中文字幕 | 久热只有精品 | 91视频高清免费 | 美女视频黄免费网站 | 国产一级在线观看视频 | 亚洲91精品在线观看 | 最新成人av | 国产精品久久久电影 | 国产麻豆果冻传媒在线观看 | 日韩免费观看高清 | 日韩在线视| 日本在线视频网址 | 天天射网| 国偷自产中文字幕亚洲手机在线 | 欧美精品久久天天躁 | 久久亚洲综合国产精品99麻豆的功能介绍 | 2018好看的中文在线观看 | av在线播放网址 | 97视频在线观看免费 | 又大又硬又黄又爽视频在线观看 | 精品亚洲免费视频 | 久久久久久综合 | 亚洲欧美日韩精品一区二区 | 91天堂在线观看 | 91日韩在线专区 | 久久一区国产 | 丁香五香天综合情 | 久热香蕉视频 | 天天爽夜夜爽精品视频婷婷 | 久久人人爽视频 | 久久久久免费网站 | 99人久久精品视频最新地址 | 亚洲精品mv在线观看 | 五月激情丁香图片 | 三上悠亚在线免费 | 国产在线观看高清视频 | 日日干夜夜干 | 成人国产精品免费 | 性色va| 99riav1国产精品视频 | 国产精品 国产精品 | 麻豆一精品传二传媒短视频 | 免费看污片 | 97品白浆高清久久久久久 | 国内精品久久久久国产 | 欧美日韩精品免费观看视频 | 亚洲精品影视在线观看 | 亚洲色图 校园春色 | 亚洲国产黄色片 | 中文字幕av在线 | 久久天天躁夜夜躁狠狠85麻豆 | 久久久久亚洲精品男人的天堂 | 成人黄色中文字幕 | 一区二区三区国产欧美 | 国产资源免费在线观看 | 国产91精品久久久久久 | 日本不卡一区二区 | 国产成人三级一区二区在线观看一 | 手机av看片 | 国内丰满少妇猛烈精品播 | 亚洲综合视频在线 | 免费无遮挡动漫网站 | 黄色www在线观看 | 黄色日批网站 | 色在线中文字幕 | 亚洲国产精品一区二区久久,亚洲午夜 | 日日摸日日爽 | 国产精品一区二区av日韩在线 | 欧美成人精品在线 | 久草视频免费 | 久久天天综合网 | 成人久久久久久久久久 | a级一a一级在线观看 | 91看片网址 | 99中文字幕视频 | 国产精品毛片完整版 | 国产91小视频 | 亚洲精品国产精品乱码在线观看 | 中国精品少妇 | 97免费在线观看 | 激情欧美日韩一区二区 | 国产黄色av影视 | www.色综合.com | 亚洲黄色一级视频 | 热久久影视 | 在线观看av中文字幕 | 国产欧美精品xxxx另类 | 97成人精品视频在线观看 | 波多野结衣理论片 | 日日操日日插 | 视频二区在线视频 | 国产日产精品一区二区三区四区 | 99精品国产在热久久 | 欧美91精品久久久久国产性生爱 | 综合网成人 | 黄色软件视频网站 | 999久久久免费视频 午夜国产在线观看 | 久久人人爽爽人人爽人人片av | 在线观看资源 | 国产精品久久久久久久久久久免费 | 日韩电影在线观看一区二区三区 | 在线观看av网站 | 免费视频资源 | 在线电影 一区 | 最近中文字幕在线 | 欧美日韩中文国产一区发布 | 精品国产精品久久 | 欧美一区二区精美视频 | 97精品国自产拍在线观看 | 欧美日韩在线视频一区二区 | 中文字幕在线视频国产 | 欧美日韩国产精品一区二区 | 国产色婷婷精品综合在线手机播放 | 精品亚洲免费 | 中文字幕免费不卡视频 | 精品福利在线视频 | 99视频+国产日韩欧美 | 美女免费黄网站 | 亚洲免费成人av电影 | 免费日韩 精品中文字幕视频在线 | 国产精品午夜在线观看 | av电影免费在线看 | 亚洲色影爱久久精品 | 天天色播 | 俺要去色综合狠狠 | 亚洲专区在线播放 | 久久精品中文字幕免费mv | 在线观看一 | 婷婷婷国产在线视频 | 亚洲三级黄色 | 午夜视频久久久 | 天天爽夜夜爽精品视频婷婷 | 免费在线观看视频一区 | 日韩理论片在线 | 久久精品视频国产 | 久久综合日 | 99久久精品免费视频 | 13日本xxxxxⅹxxx20| 99热9 | 日韩小视频 | www.亚洲精品 | 亚洲精品在线二区 | 韩日电影在线观看 | 超碰伊人网 | 97色se| 97超碰资源 | 二区三区在线视频 | 久操视频在线 | 国产片免费在线观看视频 | 天天射天天干天天爽 | 日韩免费观看视频 | 蜜臀久久99精品久久久无需会员 | 日韩精品中文字幕在线观看 | 精品一区二区影视 | 8x8x在线观看视频 | 五月天六月婷婷 | 国产精品入口传媒 | 99色国产| 色www精品视频在线观看 | 亚洲国产丝袜在线观看 | 国产免费作爱视频 | 美女国产网站 | av一级一片| 九九久久久久99精品 | 人人爱在线视频 | 国产精品视频免费看 | 亚洲欧美在线视频免费 | 在线观看国产日韩 | av成人免费网站 | 九九免费观看全部免费视频 | 久久精品电影 | www.av在线.com | 久久九九久久 | 国产手机av | 婷婷久月 | 日本高清中文字幕有码在线 | 九九综合久久 | 国产玖玖在线 | 首页中文字幕 | 国产精品久久电影网 | 九九久久国产精品 | 国内成人av| 91热视频| 日本三级吹潮在线 | 久久精品99国产精品日本 | 成人在线视频免费观看 | av网站在线观看免费 | 麻豆传媒视频观看 | 四虎精品成人免费网站 | 探花视频在线版播放免费观看 | 精品在线观看免费 | 91免费版在线 | 日韩精品一区不卡 | 国语精品久久 | 夜夜操天天操 | 黄色特一级片 | 国产黄色片免费 | 99精品久久久 | 亚洲第一久久久 | 久久a热6| 久久久久久久久久久免费视频 | 久久综合九色综合网站 | 五月婷婷丁香网 | 亚洲精品视频第一页 | 国产视频精选在线 | 久久久久久久毛片 | 久久久精品免费观看 | 日韩乱理 | 日本黄色大片免费看 | 久久久一本精品99久久精品 | 亚洲精选久久 | 97超碰在线免费观看 | 不卡的一区二区三区 | 国产一区二区在线免费播放 | av黄免费看| 伊人官网 | 亚洲成av | 在线黄色国产 | 91成人精品一区在线播放69 | 色综合综合 | 婷婷丁香视频 | 超碰免费97 | 西西www4444大胆在线 | 成人免费共享视频 | 亚洲理论在线观看电影 | 国产精品国产三级在线专区 | 久草在线手机视频 | 日韩在线观看视频网站 | 亚洲一级性 | 91在线视频在线观看 | 在线观看黄 | 亚洲成av片人久久久 | 免费成人在线电影 | 中文字幕 91 | 黄色国产成人 | 日韩欧美69| 99热这里只有精品在线观看 | 欧美 日韩精品 | 99在线精品观看 | 丁香国产视频 | 99久久日韩精品免费热麻豆美女 | 精品嫩模福利一区二区蜜臀 | 美女久久视频 | 久久人人爽人人爽 | 中文字幕在线观看网址 | 色妞久久福利网 | 婷婷丁香导航 | 国产精品v欧美精品v日韩 | 日韩国产精品久久 | 午夜精品久久久久99热app | 81精品国产乱码久久久久久 | 日韩激情中文字幕 | 欧美美女视频在线观看 | 国产麻豆精品一区二区 | 奇米网在线观看 | 97超碰在线免费观看 | 久久av不卡 | 婷婷激情欧美 | 国产色综合 | 69亚洲精品| 超碰在线91 | 日韩性xxx | 久久国产精品系列 | 91麻豆国产福利在线观看 | 国产成人精品av | 亚洲综合视频在线播放 | 狠狠狠色丁香婷婷综合激情 | 日韩激情三级 | av高清影院 | 免费av在线| 国产乱码精品一区二区蜜臀 | 欧美日韩免费观看一区=区三区 | 欧美一级片在线观看视频 | 国产成人一区二区三区电影 | 欧美日韩一区久久 | 国产中的精品av小宝探花 | 在线播放国产一区二区三区 | 久久免费黄色 | 国产剧情在线一区 | 狠狠色丁香久久综合网 | 久久99国产精品自在自在app | 国产免费精彩视频 | 在线观看中文av | 在线免费色 | 日韩欧美大片免费观看 | 91精品视频在线观看免费 | 91高清在线| 国产成人香蕉 | 国产精品久久久久久久久久白浆 | 四虎国产精品免费 | 国产精品美女www爽爽爽视频 | 国产尤物在线视频 | 国产一区免费 | 色婷婷狠狠 | 日韩欧美综合精品 | 亚洲精品h| 精品亚洲男同gayvideo网站 | 在线中文字幕av观看 | 成人免费视频网站 | 97超碰国产精品 | 国产不卡精品视频 | 国内精品久久天天躁人人爽 | 亚洲婷婷伊人 | 亚洲精品视频免费在线 | 免费在线国产视频 | 欧美日本一区 | 精品高清视频 | 久久久久久97三级 | 国产在线观看网站 | 久久99国产精品久久99 | 久久夜色精品国产欧美乱 | 福利视频网址 | 欧美aaa视频 | 国产一二区视频 | 国产破处在线视频 | 97看片网 | 久久tv | 日韩视频在线观看视频 | 天天干夜夜夜 | 精品亚洲va在线va天堂资源站 | 九九九电影免费看 | 伊人久操| 亚洲日本中文字幕在线观看 | 96视频免费在线观看 | 久久激情视频网 | 欧美日韩伦理在线 | 日本久久久影视 | 国产手机在线 | 日本久久高清视频 | 91高清不卡 | 亚洲综合色视频在线观看 | 亚洲黄色免费网站 | 日韩激情视频在线观看 | 国产精品免费观看网站 | 亚洲精品国产日韩 | 玖玖视频在线 | 国产成人高清在线 | 成人欧美一区二区三区黑人麻豆 | 在线综合 亚洲 欧美在线视频 | 国产中文在线观看 | 久久久国产在线视频 | 激情综合久久 | 久久理论电影网 | 国产又粗又猛又色 | 伊人婷婷久久 | 99精品99| 国产色视频网站 | 99国产精品免费网站 | 国产亚洲精品久久久久久久久久 | 中文字幕高清 | 国产成年免费视频 | 一区二区三区国 | 中文字幕在线视频一区二区三区 | 日韩精品一区二区三区三炮视频 | 久久99亚洲精品久久久久 | 亚洲乱亚洲乱妇 | 日本二区三区在线 | 九九久久影院 | 91爱爱中文字幕 | 麻花豆传媒一二三产区 | 久久精品视频国产 | 国产精品手机视频 | 天堂久久电影网 | 最近中文字幕免费视频 | 国产一级免费视频 | 久久视频一区二区 | 欧美日韩二三区 | 超碰成人av | 99人成在线观看视频 | 深爱五月激情网 | 免费视频国产 | 五月婷香蕉久色在线看 | 五月天激情电影 | 精品国产一区二 | 中文字幕免费高清av | 国产在线传媒 | av电影一区二区三区 | 亚洲乱码中文字幕综合 | 久久久久国产一区二区三区 | 国产精品9999久久久久仙踪林 | 69国产成人综合久久精品欧美 | 久久国产精品成人免费浪潮 | 精品在线播放视频 | 国产网站av | 欧美一级电影免费观看 | 亚洲天天综合网 | 免费影视大全推荐 | 99久久99久久精品免费 | www.色com | 一区在线观看 | 伊人激情综合 | 一区二区三区电影大全 | 亚洲精品系列 | 亚洲欧美综合 | 亚洲精品国产精品久久99 | 五月激情综合婷婷 | 日韩亚洲在线 | av成人免费在线 | 国产日韩在线视频 | 手机av资源 | 久草在线视频看看 | 久久草在线视频国产 | 狠狠的干狠狠的操 | 一区二区三区免费网站 | 亚洲成人黄色网址 | av免费线看 | jizz999| 免费高清在线视频一区· | 免费看的黄色小视频 | 久久电影色 | 四虎5151久久欧美毛片 | 亚洲精品在线国产 | av中文字幕在线观看网站 | 国产精品专区在线 | 日本精品一 | 午夜在线资源 | 国产a免费 | 天堂久久电影网 | 婷婷网在线| www.久久爱.cn | 国产在线最新 | 久久婷婷国产 | 超碰人人超 | 天堂网一区二区三区 | 97超碰在线人人 | 国产精品亚洲成人 | 久久久午夜视频 | 黄色软件网站在线观看 | 极品久久久久 | 免费观看一区二区三区视频 | 成年人天堂com | 激情久久综合网 | 日韩欧美一二三 | 日日操日日操 | 久操中文字幕在线观看 | 免费福利在线视频 | 韩国精品福利一区二区三区 | 黄色大片免费播放 | 天天综合导航 | 91av播放 | www.色五月.com| a视频在线观看 | 国产日韩视频在线播放 | 久久免费a | 超碰资源在线 | 高清精品在线 | 久草热久草视频 | 97色婷婷| 亚洲动漫在线观看 | 欧美一区二区精品在线 | 久久玖| 亚洲 中文 在线 精品 | 欧美性极品xxxx娇小 | 精品超碰| 国产呻吟在线 | 韩日精品在线观看 | 一区二区三区四区五区在线 | 日本美女xx | 日韩免费看片 | 日本女人的性生活视频 | 麻豆精品在线视频 | 国产日韩欧美中文 | 高清一区二区三区av | 亚洲精品国偷自产在线99热 | 国产超碰在线观看 | 日韩色视频在线观看 | 国产日韩欧美网站 | 中文字幕 成人 | 久久精品国产第一区二区三区 | aⅴ精品av导航 | 一区二区三区动漫 | 精品一二区| 91高清不卡 | 蜜臀一区二区三区精品免费视频 | 91av观看| 国产97在线播放 | 国产小视频在线观看免费 | 久久99热国产 | 久久久久亚洲精品 | 亚洲丝袜中文 | 国产精品福利在线播放 | 国产色就色 | 免费精品视频在线观看 | 色综合久久悠悠 | 免费国产在线观看 | 超碰在线人人草 | 蜜臀av性久久久久蜜臀aⅴ流畅 | 久操视频在线播放 | 国产永久免费 | 久久视频网址 | 成人精品电影 | 97免费| 亚洲精品乱码久久久久久蜜桃不爽 | 奇米影视在线99精品 | 99精品在线 | 久久久久免费网站 | 精品视频亚洲 | 在线观看va | 国产精品精品久久久久久 | 福利一区在线视频 | av久久在线| 青青草国产精品视频 | 久久在线| 亚洲综合成人婷婷小说 | 亚洲精品va| 国产99一区视频免费 | av高清一区二区三区 | 黄色小说18 | 亚洲天天在线 | 六月天色婷婷 | 91精品啪在线观看国产线免费 | 99久久99视频只有精品 | 亚洲一区网站 | 九九在线视频 | 又黄又刺激视频 | 精品久久精品久久 | 国产日韩欧美在线观看 | 成人黄色大片在线免费观看 | 欧美成人69av | 国产麻豆精品一区二区 | 国产中文字幕一区二区 | 国产糖心vlog在线观看 | 一区二区国产精品 | 国产精品综合在线观看 | 麻豆一区在线观看 | 激情久久久久 | 二区中文字幕 | 国产成人精品亚洲a | 免费成人av电影 | 在线观看免费一区 | 4438全国亚洲精品在线观看视频 | 在线观看视频三级 | 午夜久久久久久久久久影院 | 国产视频99| 91人人澡人人爽人人精品 | 中文字幕亚洲字幕 | 免费观看国产视频 | 久久久久久免费网 | 国产99久久久精品 | 成人黄视频 | 五月黄色| 久草在线视频精品 | 久99久中文字幕在线 | 国产精品久久久久久久久岛 | av一区在线播放 | 婷婷综合av| 一级a毛片高清视频 | 欧美一区影院 | 黄色片软件网站 | 久久精品女人毛片国产 | 91av免费看 | 欧美日韩69| 日韩综合一区二区 | 免费a视频 | 天堂av网址 | 成人在线播放免费观看 | 天天干夜夜擦 | 久久a久久| 婷婷久久网| 亚洲成av人片在线观看香蕉 | 精品天堂av | 91秒拍国产福利一区 | 久久久69 | 日韩av电影免费在线观看 | 成人黄色电影免费观看 | 国产日产精品久久久久快鸭 | 免费能看的av | 综合久久一本 | 91中文字幕永久在线 | 开心激情五月婷婷 | 日韩精品一区二区三区电影 | 国产精品高清在线观看 |