abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 03:22 | Nová verze

    Byla vydána nová verze 26.1.30 svobodného multiplatformního video editoru Shotcut (Wikipedie) postaveného nad multimediálním frameworkem MLT. S podporou hardwarového dekódování videa. Shotcut je vedle zdrojových kódů k dispozici také ve formátech AppImage, Flatpak a Snap.

    Ladislav Hagara | Komentářů: 0
    dnes 03:00 | Nová verze

    LibrePCB, tj. svobodný multiplatformní softwarový nástroj pro návrh desek plošných spojů (PCB), byl po deseti měsících od vydání verze 1.3 vydán ve verzi 2.0.0. Přehled novinek v příspěvku na blogu a v aktualizované dokumentaci. Zdrojové kódy LibrePCB jsou k dispozici na GitHubu pod licencí GPLv3.

    Ladislav Hagara | Komentářů: 0
    včera 21:11 | Komunita

    Guido van Rossum, tvůrce programovacího jazyka Python, oslavil 70. narozeniny. Narodil se 31. ledna 1956 v nizozemském Haarlemu.

    Ladislav Hagara | Komentářů: 1
    včera 12:22 | Zajímavý software

    OpenClaw je open-source AI asistent pro vykonávaní různých úkolů, ovládaný uživatelem prostřednictvím běžných chatovacích aplikací jako jsou například WhatsApp, Telegram nebo Discord. Asistent podporuje jak různé cloudové modely, tak i lokální, nicméně doporučován je pouze proprietární model Claude Opus 4.5 od firmy Anthropic v placené variantě. GitHubová stránka projektu OpenClaw.

    NUKE GAZA! 🎆 | Komentářů: 2
    včera 03:00 | Komunita

    Projekt VideoLAN a multimediální přehrávač VLC (Wikipedie) dnes slaví 25 let. Vlastní, tenkrát ještě studentský projekt, začal již v roce 1996 na vysoké škole École Centrale Paris. V první únorový den roku 2001 ale škola oficiálně povolila přelicencování zdrojových kódů na GPL a tím pádem umožnila používání VLC mimo akademickou půdu.

    Ladislav Hagara | Komentářů: 1
    31.1. 18:11 | Humor

    Moltbook je sociální síť podobná Redditu, ovšem pouze pro agenty umělé inteligence - lidé se mohou účastnit pouze jako pozorovatelé. Agenti tam například rozebírají podivné chování lidí, hledají chyby své vlastní sociální sítě, případně spolu filozofují o existenciálních otázkách 🤖.

    NUKE GAZA! 🎆 | Komentářů: 3
    31.1. 18:00 | Humor

    scx_horoscope je „vědecky pochybný, kosmicky vtipný“ plně funkční plánovač CPU založený na sched_ext. Počítá s polohami Slunce a planet, fázemi měsíce a znameními zvěrokruhu. Upozornil na něj PC Gamer.

    |🇵🇸 | Komentářů: 4
    30.1. 18:22 | Komunita

    O víkendu probíhá v Bruselu konference FOSDEM 2026 (Free and Open source Software Developers’ European Meeting). Program konference je velice nabitý: 37 místností, 71 tracků, 1184 přednášejících, 1069 přednášek, prezentací a workshopů. Sledovat je lze i online. K dispozici budou jejich videozáznamy. Aktuální dění lze sledovat na sociálních sítích.

    Ladislav Hagara | Komentářů: 4
    30.1. 18:00 | IT novinky

    Společnost Nex Computer stojící za "notebooky bez procesorů a pamětí" NexDock představila telefon NexPhone, který může funguje jako desktop PC, stačí k němu připojit monitor, klávesnici a myš nebo NexDock. Telefon by měl být k dispozici ve třetím čtvrtletí letošního roku. Jeho cena by měla být 549 dolarů. Předobjednat jej lze s vratní zálohou 199 dolarů. V dual-bootu by měl být předinstalovaný Android s Linuxem (Debian) jako aplikací a Windows 11.

    Ladislav Hagara | Komentářů: 3
    30.1. 16:00 | Nová verze

    Byla vydána nová major verze 9.0 softwaru pro správu elektronických knih Calibre (Wikipedie). Přehled novinek v poznámkách k vydání. Vypíchnuta je podpora AI.

    Ladislav Hagara | Komentářů: 3
    Které desktopové prostředí na Linuxu používáte?
     (19%)
     (6%)
     (0%)
     (10%)
     (24%)
     (3%)
     (5%)
     (2%)
     (11%)
     (31%)
    Celkem 719 hlasů
     Komentářů: 22, poslední 29.1. 23:06
    Rozcestník

    Dotaz: Python a opakovany vypis dat z databaze

    14.2.2016 20:26 Tomis
    Python a opakovany vypis dat z databaze
    Přečteno: 1070×
    Dobry den, chtel bych ze zeptat jak spravne opakovane vypsat hodnoty nactene z databaze. Zde cast kodu:
    
    kody_all = cur.execute(SELECT)
    #kody_all = (('010',),('020',),('030',))
    
    for kod in kody_all:
      print kod[0]
    
    print " a jeste jednou....."
    
    for kod in kody_all:
      print kod[0]
    
    con.close()
    
    Kdyz kody_all nactu z databaze, tak pri prvnim behu smycky FOR se vsechny udaje vypisou, ale pri behu te dalsi smycky se uz nevypise nic. Kdyz kody_all nastavim pomoci toho zakomentovaneho radku, tak vypsani probehne v obou smyckach.

    Jedine co mi funguje je pred kazdou smyckou FOR pridat znova kody_all = cur.execute(SELECT) , ale to znamena, ze dojde k opakovanemu nacteni dat z DB? To mi neprijde zrovna spravne.....

    Muzete mi prosim poradit, jak ty udaje z DB vypsat opakovane? Dekuji.

    Řešení dotazu:


    Odpovědi

    14.2.2016 21:52 divbyzero | skóre: 6
    Rozbalit Rozbalit vše Re: Python a opakovany vypis dat z databaze
    Dobry den, co si ulozit vysledek do mezipromenne?
    kody_current = kody_all
    
    14.2.2016 21:59 Kit | skóre: 46 | Brno
    Rozbalit Rozbalit vše Re: Python a opakovany vypis dat z databaze
    Problém spočívá v tom, že proměnná kody_all není pole, ale iterovatelná strukrura, která se bohužel neumí "převinout na začátek".

    Správně bys to měl překopírovat do nové struktury, která se už bude chovat dle tvých potřeb. Nejlépe do nějakého objektu nebo přinejhorším do pole.
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    14.2.2016 22:10 Kit | skóre: 46 | Brno
    Rozbalit Rozbalit vše Re: Python a opakovany vypis dat z databaze
    Teď na to koukám, zkus tohle:
    kody_all = cur.execute(SELECT).fetchall()
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    14.2.2016 22:22 Tomis
    Rozbalit Rozbalit vše Re: Python a opakovany vypis dat z databaze
    Jo, moc dekuji, tohle uz funguje. Muzes mi prosim jeste trochu naznacit, co se tim fetchall() zmenilo?
    14.2.2016 22:26 Kit | skóre: 46 | Brno
    Rozbalit Rozbalit vše Re: Python a opakovany vypis dat z databaze
    Ze zmíněné iterovatelné struktury (viz výše) se stalo obyčejné pole, resp. seznam.
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    19.4.2016 05:25 eee
    Rozbalit Rozbalit vše Re: Python a opakovany vypis dat z databaze
    To neni dobre vysvetleni. Spravne vysvetleni je, ze execute vraci kurzor, ktery kazdym zavolanim vrati z db jeden radek. Volanim fetchall() primejeme kurzor vratit cely vysledek jako list radku.
    15.2.2016 08:27 Filip Jirsák
    Rozbalit Rozbalit vše Re: Python a opakovany vypis dat z databaze
    Ten váš kód postupně donačítá výsledky z databáze – bude tedy fungovat i pro hodně velké objemy dat, protože se vždy přenese jenom část výsledků. Na druhou stranu se ve výsledcích můžete pohybovat pořád jen dopředu, takže když je potřebujete vypsat vícekrát, musíte dotaz zavolat opakovaně v jedné transakci (a nastavit správnou úroveň izolace transakcí, aby vracel vždy stejné výsledky). Upravený kód dělá to, že nejprve načte všechny výsledky z databáze do paměti, takže je pak můžete procházet libovolně. Nevýhoda je, že se vše načte najednou do paměti, takže jste omezen velikostí dostupné paměti a víc výsledků takhle nezpracujete.
    15.2.2016 09:19 Kit | skóre: 46 | Brno
    Rozbalit Rozbalit vše Re: Python a opakovany vypis dat z databaze
    Pokud jsou data načítaná z databáze jen menšího rozsahu (řekněme < 1 MB), tak se o takové nevýhodě vůbec nemá smysl bavit. Pro většinu běžných případů tedy výhody kompletního načtení převažují.

    Za nejlepší řešení však stále považuji použití načtených dat pouze 1×. V opačném případě mi v takové aplikaci "něco smrdí".
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    15.2.2016 11:31 Filip Jirsák
    Rozbalit Rozbalit vše Re: Python a opakovany vypis dat z databaze
    O rozsahu dat nic nevíme. Pokud to budou stovky GB, nemá zase vůbec smysl bavit se o tom, že se to celé načte do paměti…
    15.2.2016 12:14 Tomis
    Rozbalit Rozbalit vše Re: Python a opakovany vypis dat z databaze
    Dobry den, databaze je sice velka (cca 100GB), ale ja nacitam pouze 3 sloupce z jedne tabulky. a nacitam vzdy jenom data z minuleho dne, takze se uz nijak nemeni. Tech zaznamu za den je kolem 5000. Takze ten fetchall() mi takto vyhovuje.

    15.2.2016 15:53 Kit | skóre: 46 | Brno
    Rozbalit Rozbalit vše Re: Python a opakovany vypis dat z databaze
    Pokud to budou stovky GB, nemá zase smysl bavit se o dvojitém načítání. Je nutné to načíst jednou a ihned zpracovat podobojí.
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    15.2.2016 21:26 Filip Jirsák
    Rozbalit Rozbalit vše Re: Python a opakovany vypis dat z databaze
    Pokud to jde. Pokud bude potřeba to poslat jako soubor přes HTTP a v hlavičce bude hash toho souboru, nic jiného vám nezbyde. Jasně, jsou to extrémní příklady. Jde spíš o to, že „načíst všechno do paměti“ je jednoduché řešení pro jednoduché případy, které ale neškáluje. Proudové zpracování se hodí nejen pro velký objem dat, ale také umožní třeba paralelní zpracování (ať už využití více jader CPU na jednom stroji, nebo zpracování na více uzlech v cloudu).
    15.2.2016 22:16 Kit | skóre: 46 | Brno
    Rozbalit Rozbalit vše Re: Python a opakovany vypis dat z databaze
    Tady na fóru se řeší hlavně jednoduché příklady, u kterých to škálování chybět nebude.

    99 % běžných případů vyřeší inženýři a to zbylé 1 % přenechají doktorům, aby se měli v čem rýpat a aby také něco dělali :-)

    A ten velký soubor? Uložím ho do tempu, spočítám hash a obojí pošlu klientovi. Do databáze se podruhé hrabat nebudu, protože se jistě mezitím změnil její obsah a držet ji celou dobu pod krkem by také nemuselo být zrovna košér.

    A když už jsme u těch velkých objemů dat, tak hash používám jako klíč k přístupu k takovým datům a proto bych ho klientovi jednoduše přibalil.
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    15.2.2016 12:04 blondak | skóre: 36 | blog: Blondak | Čáslav
    Rozbalit Rozbalit vše Re: Python a opakovany vypis dat z databaze
    Neznám sice Python, a ani nepíšete na jaké to má být databázi, ale třeba mysql v php má funkci mysql(i)_data_seek, pro sqlite sqlite_rewind
    Každý problém ma své logické, snadno pochopitelné nesprávné řešení.

    Založit nové vláknoNahoru

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.