您好,登錄后才能下訂單哦!
Python中的shelve模塊是什么?很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。
shelve模塊
使用json或者pickle持久化數據,能dump多次,但load的話只能取到最新的dump, 因為先前的數據已經被后面dump的數據覆蓋掉了。如果想要實現dump多次不被覆蓋,就可以想到使用shelve模塊。shelve模塊可以持久化所有pickle所支持的數據類型。另外,寫程序的時候如果不想用關系數據庫那種重量級的去存儲數據,也可以用到shelve。
shelve是用key來訪問的,使用起來和字典類似。 要注意的是,在shelve模塊中,key必須為字符串,而值可以是python所支持的數據類型。
另外,shelve其實用anydbm去創建DB并且管理持久化對象的。
shelve只提供給我們一個open方法,是用key來訪問的,使用起來和字典類似。 可以像字典一樣使用get來獲取數據等。
如下操作:
import shelve f_shelve = shelve.open('shelve') # 創建一個文件句柄 f_shelve["name"] = "小明" # 向文件中存放數據 f_shelve["age"] = 21 # 向文件中存放數據 f_shelve["sex"] = "男"
運行后會生成3個文件:shelve.bak shelve.dat shelve.dir
shelve.dat 存儲的就是b字節數據類型的數據。bak和dir后綴從字面上看是備份和目錄,具體做什么的不是很清楚。
當我們寫好數據后,如何讀取呢?
import shelve f_shelve = shelve.open('shelve') # 創建一個文件句柄 # 打印文件內容,和類型 print(f_shelve["name"],f_shelve["age"],f_shelve["sex"],type(f_shelve))
打印內容如下
小明 21 男 <class 'shelve.DbfilenameShelf'>
既然f_shelve類似于字典,那我們也可以使用for循環進行打印,如下:
import shelve f_shelve = shelve.open('shelve') # 創建一個文件句柄 # 使用for循環打印內容 for k,v in f_shelve.items(): print(k,v)
打印內容如下
name 小明 age 21 sex 男
f_shelve現在是一個特殊的文件句柄,它可以執行字典的多數方法,對文件里的數據進行操作。
import shelve f_shelve = shelve.open('shelve') # 創建一個文件句柄 f_shelve["list"] = [1,2,3] # 向文件中添加數據列表 f_shelve["list"].append("abc") # 向列表中追加內容. f_shelve["list"].pop(1) # 從列表中刪除一個元素 f_shelve["name"] = "小明" # 向文件中追加內容 f_shelve["name"] = "小紅" # 修改name所對應的值 print(f_shelve["list"],f_shelve["name"],sep="\n")
打印內容如下
[1, 2, 3] 小紅
通過上面的打印內容我們可以發現,我們將列表寫入文件后,然后在讀取出來進行追加和刪除元素,并沒有對文件產生影響,文件中的列表內容還是原來的值。而我們向文件中添加字符串時,在讀取出來對字符串進行修改發現數據被修改了。
由此我們可以知道在向文件中寫入一個可變的數據時,如果讀取出來對數據進行修改只是在內存中的修改,修改后的數據并沒有被真正寫入到文件中。那么我們該如何進行操作呢?這時就需要回寫了。
import shelve # 創建一個特殊的文件句柄,并添加回寫功能 f_shelve = shelve.open('shelve',writeback=True) # 啟用會寫 f_shelve["list"] = [1,2,3] # 向文件中添加數據列表 f_shelve["list"].append("abc") # 向列表中追加內容. f_shelve["list"].pop(1) # 從列表中刪除一個元素 print(f_shelve["list"])
打印內容如下
[1, 3, 'abc']
這回我們在修改列表時,可以看出列表的數據確實被修改了。
總結如下:
1、shelve模塊將內存數據以字典的類型(key,value)通過文件持久化,模擬出簡單的db效果。
2、shelve模塊可以持久化任何pickle所支持的python數據格式,但是它的key必需得是字符串。
3、shelve可以看作是pickle模塊的一個封裝,但它實現了可以多次dump(后面的dump不會覆蓋前面的)和多次load。
4、shelve訪問己有key時,實際上取出的是數據源給出的一份拷貝,所以對于拷貝做出的增加和刪除等操作都需要用writeback=True參數才能實現寫入回文件中進行修改。
5、shelve對于d[key] = data這種操作,視為存儲數據,無則新增,有則覆蓋,
對與訪問key當中的值(條目)進行修改,默認不回寫并不矛盾和沖突。
看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。