国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

Python基礎之(十一)數據存儲

Songlcy / 2294人閱讀

摘要:默認為或者說,是以格式保存對象如果設置為或者,則以壓縮的二進制格式保存對象。但是,要小心坑試圖增加一個坑就在這里當試圖修改一個已有鍵的值時沒有報錯,但是并沒有修改成功。要填平這個坑,需要這樣做多一個參數沒有坑了還用循環一下

pickle

pickle是標準庫中的一個模塊,在Python 2中還有一個cpickle,兩者的區別就是后者更快。所以,下面操作中,不管是用import pickle,還是用import cpickle as pickle,在功能上都是一樣的。

而在Python 3中,你只需要import pickle即可,因為它已經在Python 3中具備了Python 2中的cpickle同樣的性能。

pickle.dump(obj,file[,protocol])

obj:序列化對象,在上面的例子中是一個列表,它是基本類型,也可以序列化自己定義的對象。

file:要寫入的文件。可以更廣泛地可以理解為為擁有write()方法的對象,并且能接受字符串為為參數,所以,它還可以是一個StringIO對象,或者其它自定義滿足條件的對象。

protocol:可選項。默認為False(或者說0),是以ASCII格式保存對象;如果設置為1或者True,則以壓縮的二進制格式保存對象。

序列化對象

</>復制代碼

  1. >>> import pickle
  2. >>> d = {}
  3. >>> integers = range(9999)
  4. >>> d["i"] = integers #下面將這個字典類型的對象存入文件
  5. >>> f = open("22902.dat", "wb")
  6. >>> pickle.dump(d, f) #文件中以ascii格式保存數據
  7. >>> f.close()
  8. >>> f = open("22903.dat", "wb")
  9. >>> pickle.dump(d, f, True) #文件中以二進制格式保存數據,文件較小,推薦方式
  10. >>> f.close()
  11. >>> import os
  12. >>> s1 = os.stat("22902.dat").st_size #得到兩個文件的大小
  13. >>> s2 = os.stat("22903.dat").st_size
  14. >>> print "%d, %d, %.2f%%" % (s1, s2, (s2+0.0)/s1*100) #Python 3: print("{0:d}, {1:d}, {2:.2f}".format (s1, s2, (s2+0.0)/s1*100))
  15. 68903, 29774, 43.21%
反序列化對象

</>復制代碼

  1. 將數據保存入文件,還有另外一個目標,就是要讀出來,也稱之為反序列化。
  2. >>> integers = pickle.load(open("22901.dat", "rb"))
  3. >>> print integers #Python 3: print(integers)
  4. [1, 2, 3, 4, 5]
  5. 再看看以二進制存入的那個文件:
  6. >>> f = open("22903.dat", "rb")
  7. >>> d = pickle.load(f)
  8. >>> print d
  9. {"i": [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, .... #省略后面的數字}
  10. >>> f.close()
讀取自定義對象

</>復制代碼

  1. >>> import cPickle as pickle #這是Python 2的引入方式,如果是Python 3,直接使用import pickle
  2. >>> import StringIO #標準庫中的一個模塊,跟file功能類似,只不過是在內存中操作“文件”
  3. >>> class Book(object): #自定義一種類型
  4. ... def __init__(self,name):
  5. ... self.name = name
  6. ... def my_book(self):
  7. ... print "my book is: ", self.name #Python 3: print("my book is: ", self.name)
  8. ...
  9. # 存數據
  10. >>> file = StringIO.StringIO()
  11. >>> pickle.dump(pybook, file, 1)
  12. # 取數據
  13. >>> file.seek(0) #找到對應類型
  14. >>> pybook2 = pickle.load(file)
  15. >>> pybook2.my_book()
  16. my book is:
  17. >>> file.close()
shelve

由于數據的復雜性,pickle只能完成一部分工作,在另外更復雜的情況下,它就稍顯麻煩了。于是,又有了shelve

</>復制代碼

  1. # 寫操作
  2. >>> import shelve
  3. >>> s = shelve.open("22901.db")
  4. >>> s["name"] = "www.itdiffer.com"
  5. >>> s["lang"] = "python"
  6. >>> s["pages"] = 1000
  7. >>> s["contents"] = {"first":"base knowledge","second":"day day up"}
  8. >>> s.close()
  9. # 讀操作
  10. >>> s = shelve.open("22901.db")
  11. >>> name = s["name"]
  12. >>> print name #Python 3: print(name)
  13. www.itdiffer.com
  14. >>> contents = s["contents"]
  15. >>> print contents #Python 3: print(contents)
  16. {"second": "day day up", "first": "base knowledge"}
  17. # for循環讀
  18. >>> for k in s:
  19. ... print k, s[k]
  20. ...
  21. contents {"second": "day day up", "first": "base knowledge"}
  22. lang python
  23. pages 1000
  24. name www.itdiffer.com

所建立的對象被變量s所引用,就如同字典一樣,可稱之為類字典對象。所以,可以如同操作字典那樣來操作它。

但是,要小心坑:

</>復制代碼

  1. >>> f = shelve.open("22901.db")
  2. >>> f["author"]
  3. ["qiwsir"]
  4. >>> f["author"].append("Hetz") #試圖增加一個
  5. >>> f["author"] #坑就在這里
  6. ["qiwsir"]
  7. >>> f.close()
  8. 當試圖修改一個已有鍵的值時沒有報錯,但是并沒有修改成功。要填平這個坑,需要這樣做:
  9. >>> f = shelve.open("22901.db", writeback=True) #多一個參數True
  10. >>> f["author"].append("Hetz")
  11. >>> f["author"] #沒有坑了
  12. ["qiwsir", "Hetz"]
  13. >>> f.close()
  14. 還用`for`循環一下:
  15. >>> f = shelve.open("22901.db")
  16. >>> for k,v in f.items():
  17. ... print k,": ",v #Python 3: print(k,": ",v)
  18. ...
  19. contents : {"second": "day day up", "first": "base knowledge"}
  20. lang : python
  21. pages : 1000
  22. author : ["qiwsir", "Hetz"]
  23. name : www.itdiffer.com

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/38200.html

相關文章

  • PHP面試常考內容Memcache和Redis(2)

    摘要:繼周一發布的面試常考內容之和后,這是第二篇,感謝你的支持和閱讀。預告面試常考內容之和將于本周五更新。以上內容摘自程序員面試筆試寶典書籍,該書已在天貓京東當當等電商平臺銷售。 你好,是我琉憶。繼周一(2019.2-18)發布的PHP面試常考內容之Memcache和Redis(1)后,這是第二篇,感謝你的支持和閱讀。本周(2019.2-18至2-22)的文章內容點為以下幾點,更新時間為每周...

    Eric 評論0 收藏0
  • PHP面試常考內容Memcache和Redis(2)

    摘要:繼周一發布的面試常考內容之和后,這是第二篇,感謝你的支持和閱讀。預告面試常考內容之和將于本周五更新。以上內容摘自程序員面試筆試寶典書籍,該書已在天貓京東當當等電商平臺銷售。 你好,是我琉憶。繼周一(2019.2-18)發布的PHP面試常考內容之Memcache和Redis(1)后,這是第二篇,感謝你的支持和閱讀。本周(2019.2-18至2-22)的文章內容點為以下幾點,更新時間為每周...

    sewerganger 評論0 收藏0
  • Python爬蟲學習路線

    摘要:以下這些項目,你拿來學習學習練練手。當你每個步驟都能做到很優秀的時候,你應該考慮如何組合這四個步驟,使你的爬蟲達到效率最高,也就是所謂的爬蟲策略問題,爬蟲策略學習不是一朝一夕的事情,建議多看看一些比較優秀的爬蟲的設計方案,比如說。 (一)如何學習Python 學習Python大致可以分為以下幾個階段: 1.剛上手的時候肯定是先過一遍Python最基本的知識,比如說:變量、數據結構、語法...

    liaoyg8023 評論0 收藏0
  • [系統安全] 三十五.Procmon工具基本用法及文件進程、注冊表查看

    摘要:本文將分享軟件基本用法及文件進程注冊表查看,這是一款微軟推薦的系統監視工具,功能非常強大可用來檢測惡意軟件。可以幫助使用者對系統中的任何文件注冊表操作進行監視和記錄,通過注冊表和文件讀寫的變化,有效幫助診斷系統故障或發現惡意軟件病毒及木馬。 ...

    kk_miles 評論0 收藏0
  • Python 基礎起步 (十一) 寫在最后的話(附優秀資源匯總)

    摘要:總結不知不覺作為一個小白已經寫完了最最基礎的簡單教程,如果你也和我一樣從事金融行業,或者毫無編程基礎的小白,希望我的教程可以幫到你,這是基礎起步的最終篇,我希望能和大家簡單介紹一下后續介紹以及很多幫助到我的優秀的平臺。 總結 不知不覺作為一個小白已經寫完了最最基礎的Python簡單教程,如果你也和我一樣從事金融行業,或者毫無編程基礎的小白,希望我的教程可以幫到你,這是Python基礎起...

    mrcode 評論0 收藏0

發表評論

0條評論

最新活動
閱讀需要支付1元查看
<