Objekty vytvořené modulem shelve se chovají jako slovníky. Modul je dokáže uložit a přečíst nějakou jejich hodnotu, aniž by musel načítat ostatní data.
Modul shelve
Soubory vytvořené modulem shelve
se chovají jako slovníky. Modul dokáže uložit a přečíst nějakou jejich hodnotu aniž by musel načítat ostatní data. Možná si říkáte, že stejného efektu lze dosáhnout i pomocí modulu pickle
, ale není to tak. Pokud totiž uložíte pomocí modulu pickle
nějaký slovník a pak z něj chcete získat nějaké údaje, musíte ho nejdřív celý načíst. Oproti tomu modul shelve
dokáže vytáhnout jakoukoliv hodnotu a nemusí přitom načítat zbytek dat. Proto se tento modul hodí právě na zpracování velkého množství dat. Dalo by se tedy říci, že se tento modul dá použít jako primitivní databáze.
Jak je vám jistě známo, slovník se v podstatě skládá z dvou věcí: klíč → hodnota (key → value
). Když ukládáme nějaké věci pomocí modulu shelve
, klíč musí být vždy řetězec, ale hodnota může nabývat typu čísla, slovníku, seznamu, ... (vše, s čím si poradí modul pickle
).
Databáze se otevírá pomocí funkce db = shelve.open(jmeno)
. Pokud taková databáze neexistuje, bude vytvořena. Pak s vráceným objektem můžeme pracovat jako se slovníkem. Po dokončení čtení/zápisu dat je třeba databázi uzavřít pomocí metody db.close()
.
import shelve db = shelve.open("db.txt") db["jedna"] = 1 db.close()
Vytvořili jsme databázi jménem db.txt
. Proměnná db se chová stejně jako slovník, tj. má i stejné metody:
print db.keys()
print db.has_key("jedna")
print db.items()
Mazání z databáze může probíhat pomocí dvou způsobů:
import shelve db = shelve.open("db.txt") db["jedna"] = 1 db["dva"] = 2 del db["jedna"] db.pop("dva") print db.keys() db.close()
Nyní se dá říci, že už umíte pracovat s modulem shelve
, ale přesto je zde ještě jedna věc, která stojí za zmínku.
writeback
Při otevírání databáze se dá nastavit parametr writeback
. Pomocí toho parametru se určuje, jak bude databáze nakládat se změnami provedenými za chodu.
#standardně se databáze otevírá s writeback = False
import shelve
db = shelve.open("db.txt")
db["seznam"] = []
db["seznam"].append(1)
db["seznam"].append(2)
print db["seznam"]
db.close()
Řádek print db["seznam"]
vrátil prázdný seznam. Jak je to ale možné, když jsme do toho seznamu předtím uložili dvě hodnoty? Abychom do db["seznam"]
mohli vložit nějaké hodnoty, musíme použít následující řešení:
import shelve db = shelve.open("db.txt") db["seznam"] = [] kopie = db["seznam"] kopie.append(1) kopie.append(2) db["seznam"] = kopie print db["seznam"] db.close()
Pokud bychom nastavili writeback
na True
, fungovala by správně i první ukázka. Nicméně takto otevřená databáze je pomalejší a obecně se doporučuje nastavit writeback
na False
.
import shelve
db = shelve.open("db.txt", writeback = True)
db["seznam"] = []
db["seznam"].append(1)
db["seznam"].append(2)
print db["seznam"]
db.close()
Pro modul shelve
platí stejné podmínky, co se ukládání týče, jako pro modul pickle
. Nepodaří se vám tedy uložit například instanci Tk()
:
Traceback (most recent call last):
File "C:DOCUME~1BLUJAC~1LOCALS~1TempA7563708.py", line 4, in <module>
db["Tk"] = Tk()
File "C:Python25libshelve.py", line 123, in __setitem__
p.dump(value)
cPickle.UnpickleableError: Cannot pickle <type tkapp=""> objects
</type></module>