程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 更多編程語言 >> Python >> python核心模塊之pickle和cPickle解說

python核心模塊之pickle和cPickle解說

編輯:Python
 pickle模塊使用的數據格式是python專用的,而且不同版本號不向後兼容,同一時候也不能被其它語言說識別。要和其它語言交互,能夠使用內置的json包使用pickle模塊你能夠把Python對象直接保存到文件,而不須要把他們轉化為字符串,也不用底層的文件訪問操作把它們寫入到一個二進制文件中。 pickle模塊會創建一個python語言專用的二進制格式。你基本上不用考慮不論什麼文件細節。它會幫你干淨利落地完畢讀寫獨享操作,唯一須要的僅僅是一個合法的文件句柄。
        pickle模塊中的兩個主要函數是dump()和load()。dump()函數接受一個文件句柄和一個數據對象作為參數,把數據對象以特定的格式保存到給定的文件裡。

當我們使用load()函數從文件裡取出已保存的對象時。pickle知道怎樣恢復這些對象到它們本來的格式。



        dumps()函數運行和dump() 函數同樣的序列化。代替接受流對象並將序列化後的數據保存到磁盤文件,這個函數簡單的返回序列化的數據。

        loads()函數運行和load() 函數一樣的反序列化。代替接受一個流對象並去文件讀取序列化後的數據,它接受包括序列化後的數據的str對象, 直接返回的對象。



        cPickle是pickle得一個更快得C語言編譯版本號。


        pickle和cPickle相當於java的序列化和反序列化操作
 
#! /usr/local/env python
# -*- coding=utf-8 -*-

if __name__ == "__main__":
    import cPickle

    #序列化到文件
    obj = 123,"abcdedf",["ac",123],{"key":"value","key1":"value1"}
    print obj
    #輸出:(123, abcdedf, [ac, 123], {key1: value1, key: value})
    #r 讀寫權限 r b 讀寫到二進制文件
    f = open(r"d:a.txt","r ")
    cPickle.dump(obj,f)
    f.close()
    f = open(r"d:a.txt")
    print cPickle.load(f)
    #輸出:(123, abcdedf, [ac, 123], {key1: value1, key: value})

    #序列化到內存(字符串格式保存),然後對象能夠以不論什麼方式處理如通過網絡傳輸
    obj1 = cPickle.dumps(obj)
    print type(obj1)
    #輸出:<type str>
    print obj1
    #輸出:python專用的存儲格式
    obj2 = cPickle.loads(obj1)
    print type(obj2)
    #輸出:<type tuple>
    print obj2
    #輸出:(123, abcdedf, [ac, 123], {key1: value1, key: value})

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved