Modul Shelve
 x   TIP: Přetáhni ikonu na hlavní panel pro připnutí webu
Reklama
Reklama

Modul ShelveModul Shelve

 

Modul Shelve

Google       Google       21. 7. 2008       13 205×

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.

Reklama
Reklama

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>
Zdroj: http://www.python.org/doc/2.5/lib/module-shelve.html

×Odeslání článku na tvůj Kindle

Zadej svůj Kindle e-mail a my ti pošleme článek na tvůj Kindle.
Musíš mít povolený příjem obsahu do svého Kindle z naší e-mailové adresy kindle@programujte.com.

E-mailová adresa (např. novak@kindle.com):

TIP: Pokud chceš dostávat naše články každé ráno do svého Kindle, koukni do sekce Články do Kindle.

Tagy:
Hlasování bylo ukončeno    
0 hlasů
Google
Autor studuje na FIT ČVUT a je šéfredaktorem portálu Matematika pro každého.
Web    

Nové články

Reklama
Reklama
Obrázek ke článku Nový IT hráč na českém trhu

Nový IT hráč na českém trhu

V roce 2015 otevřela v Praze na Pankráci v budově City Tower své kanceláře společnost EPAM Systems (NYSE:EPAM), jejíž centrála se nachází v USA. Společnost byla založená v roce 1993 a od té doby prošla velkým vývojem a stále roste.

Obrázek ke článku České Radiokomunikace opět hledají nejlepší nápady pro internet věcí

České Radiokomunikace opět hledají nejlepší nápady pro internet věcí

České Radiokomunikace (CRA) pořádají druhý ročník CRA IoT Hackathonů. Zájemci z řad vývojářů a fanoušků moderních technologií mohou změřit své síly a během jediného dne sestrojit co nejzajímavější funkční prototyp zařízení, které bude komunikovat prostřednictvím sítě LoRa. CRA IoT Hackathony se letos uskuteční ve dvou fázích, na jaře a na podzim, v různých městech České republiky. Jarní běh se odstartuje 31. března v Brně a 7. dubna v Praze.

Obrázek ke článku Cloud computing je využíván stále intenzivněji

Cloud computing je využíván stále intenzivněji

Využívání cloud computingu nabývá na intenzitě. Jen v letošním roce vzroste podle analytiků trh se službami veřejného cloudu o 18 %, přičemž o téměř 37 % vzrostou služby typu IaaS. Růst o více než pětinu pak čeká služby poskytování softwaru formou služby, tedy SaaS. Aktuálním trendům v oblasti využívání cloudu se bude věnovat konference Cloud computing v praxi, která se koná 23. března. 2017 v pražském Kongresovém centru Vavruška na Karlově náměstí 5.

loadingtransparent (function() { var po = document.createElement('script'); po.type = 'text/javascript'; po.async = true; po.src = 'https://apis.google.com/js/plusone.js'; var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(po, s); })();
Hostujeme u Českého hostingu       ISSN 1801-1586       ⇡ Nahoru Webtea.cz logo © 20032017 Programujte.com
Zasadilo a pěstuje Webtea.cz, šéfredaktor Lukáš Churý