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 11:33 | IT novinky

    Nový open source router Turris Omnia NG je v prodeji. Aktuálně na Allegro, Alternetivo, Discomp, i4wifi a WiFiShop.

    Ladislav Hagara | Komentářů: 6
    dnes 05:44 | Komunita

    Na YouTube a nově také na VHSky byly zveřejněny sestříhané videozáznamy přednášek z letošního OpenAltu.

    Ladislav Hagara | Komentářů: 0
    dnes 04:33 | Komunita

    Jednou za rok otevírá společnost SUSE dveře svých kanceláří široké veřejnosti. Vítáni jsou všichni, kdo se chtějí dozvědět více o naší práci, prostředí ve kterém pracujeme a o naší firemní kultuře. Letos se dveře otevřou 26. 11. 2025 v 16:00. Můžete se těšit na krátké prezentace, které vám přiblíží, na čem naši inženýři v Praze pracují, jak spolupracujeme se zákazníky, partnery i studenty, proč máme rádi open source a co pro nás skutečně

    … více »
    SUSEMAS | Komentářů: 0
    dnes 04:22 | Komunita

    Na čem pracují vývojáři webového prohlížeče Ladybird (GitHub)? Byl publikován přehled vývoje za říjen (YouTube).

    Ladislav Hagara | Komentářů: 0
    dnes 04:11 | Zajímavý článek

    Jeff Quast otestoval současné emulátory terminálu. Zaměřil se na podporu Unicode a výkon. Vítězným emulátorem terminálu je Ghostty.

    Ladislav Hagara | Komentářů: 6
    včera 22:55 | IT novinky

    Amazon bude poskytovat cloudové služby OpenAI. Cloudová divize Amazon Web Services (AWS) uzavřela s OpenAI víceletou smlouvu za 38 miliard USD (803,1 miliardy Kč), která poskytne majiteli chatovacího robota s umělou inteligencí (AI) ChatGPT přístup ke stovkám tisíc grafických procesů Nvidia. Ty bude moci využívat k trénování a provozování svých modelů AI. Firmy to oznámily v dnešní tiskové zprávě. Společnost OpenAI také nedávno

    … více »
    Ladislav Hagara | Komentářů: 3
    včera 16:22 | Pozvánky

    Konference Prague PostgreSQL Developer Day 2026 (P2D2) se koná 27. a 28. ledna 2026. Konference je zaměřena na témata zajímavá pro uživatele a vývojáře. Příjem přednášek a workshopů je otevřen do 14. listopadu. Vítáme témata související s PostgreSQL či s databázemi obecně, a mohou být v češtině či angličtině.

    TomasVondra | Komentářů: 0
    včera 13:22 | Nová verze

    Byl vydán Devuan 6 Excalibur. Přehled novinek v poznámkách k vydání. Kódové jméno Excalibur bylo vybráno podle planetky 9499 Excalibur. Devuan (Wikipedie) je fork Debianu bez systemd. Devuan 6 Excalibur vychází z Debianu 13 Trixie. Devuan 7 ponese kódové jméno Freia.

    Ladislav Hagara | Komentářů: 4
    včera 10:44 | IT novinky

    Společnost Valve aktualizovala přehled o hardwarovém a softwarovém vybavení uživatelů služby Steam. Podíl uživatelů Linuxu poprvé překročil 3 %, aktuálně 3,05 %. Nejčastěji používané linuxové distribuce jsou Arch Linux, Linux Mint a Ubuntu. Při výběru jenom Linuxu vede SteamOS Holo s 27,18 %. Procesor AMD používá 67,10 % hráčů na Linuxu.

    Ladislav Hagara | Komentářů: 1
    včera 10:33 | Zajímavý projekt

    Joel Severin v diskusním listu LKML představil svůj projekt linuxového jádra ve WebAssembly (Wasm). Linux tak "nativně" běží ve webovém prohlížeči. Potřebné skripty pro převod jsou k dispozici na GitHubu.

    Ladislav Hagara | Komentářů: 1
    Jaké řešení používáte k vývoji / práci?
     (36%)
     (48%)
     (18%)
     (18%)
     (22%)
     (16%)
     (21%)
     (16%)
     (17%)
    Celkem 308 hlasů
     Komentářů: 15, poslední 2.11. 08:25
    Rozcestník

    Dotaz: python: pole <-> slovník

    11.5.2006 11:51 Jáchym Čepický | skóre: 29 | blog: U_Jachyma
    python: pole <-> slovník
    Přečteno: 387×
    marně hledám, jak v pythonu nějak jednoduše a elegantně převést pole na slovník.

    v perlu to jde nejpřímočařeji, jak jen možno:
    %slovnik = {}
    @pole = ['a',1,'b',2]
    %slovnik = @pole
    
    (nebo tak nějak - už zapomínám)

    jak na to v pythonu?

    Díky

    Odpovědi

    11.5.2006 12:12 Hynek (Pichi) Vychodil | skóre: 43 | blog: Pichi | Brno
    Rozbalit Rozbalit vše Re: python: pole <-> slovník

    To zapomínání je vidět :-) Přiřazení %slovnik = {} v perlu dopadne asi nějak takto:

    %slovnik = {};
    use Data::Dumper;
    print Dumper(\%slovnik);
    $VAR1 = {
              'HASH(0x8152508)' => undef
            };
    Jinak zbytek je v pohodě protože tím se ten první nesmysl přepíše :-) Jinak v perlu to jde ještě asi těmato dalšíma způsobama což ti asi utkvělo v paměti :
    $hashref={@pole};
    $hashref2={}; %$hashref2=@pole;
    Ale jak se to dělá v pythonu fakt netuším :-D

    P.S.: Jinak moje oblíbené

    @slovnik{@keys}=@values
    taky není špatné

    XML je zbytečný, pomalý, nešikovný balast, znovu vynalézané kolo a ještě ke všemu šišaté, těžké a kýčovitě pomalované.
    11.5.2006 12:17 Jáchym Čepický | skóre: 29 | blog: U_Jachyma
    Rozbalit Rozbalit vše Re: python: pole <-> slovník
    jj,

    no, mě jde tedy konkrétně o
    slovnik = retezec.split(",")
    
    11.5.2006 14:50 ava
    Rozbalit Rozbalit vše Re: python: pole <-> slovník
    Myslim ze jednoduse to nepujde (i kdyz python nijak buhvijak skvele neznam), lze udelat napr dict([('a', 1), ('b', 2)]), ale ne dict(['a', 1, 'b', 2]). K cemu to potrebujes (tim chci rict, co obsahuje ten "retezec" co delis podle carek?) nedal jsi nam moc informaci..

    Jinak by to urcite slo drevacky nejakou smyckou, dalsi moznost (funguje od pythonu 2.4) by bylo treba pouzit takhle nadefinovany iterator
    	def pairwise(iterable):
    		"s -> (s0,s1), (s1,s2), (s2, s3), ..."
    		a, b = itertools.tee(iterable)
    		try:
    			b.next()
    		except StopIteration:
    			pass
    		return itertools.izip(a, b)
    
    nebo nejakou jeho modifikaci a vysledek pak prevest na dict. Kazdopadne chyba je podle me ne v tom jak to udelat, ale PROC to vubec delat.
    11.5.2006 15:55 Jáchym Čepický | skóre: 29 | blog: U_Jachyma
    Rozbalit Rozbalit vše Re: python: pole <-> slovník
    hmm no, dělam to trochu jinak, a o moc nešikovnějc ne.

    kazdopadne chyba neni nikde. program prostě dostane seznam parametrů a jejich hodnot jako řetězec oddělených čárkami.
    DataInputs = "a,1,b,2,c,3"
    
    a kvůli další práci je IMHO nejvýhodnější právě slovník
    DataInputs = {
     'a':1,
     'b':2,
     'c':3,
    }
    
    dík za tip
    11.5.2006 17:30 ava
    Rozbalit Rozbalit vše Re: python: pole <-> slovník
    Nic jednodussiho uz me bohuzel nenapada..
    
    s='a,1,b,2,c,3'
    
    kvrest = s
    d = {}
    while True:
        kvrest = kvrest.split(',', 2)
        d[kvrest[0]] = kvrest[1]
        try:
            kvrest = kvrest[2]
        except IndexError:
            break
    
    12.5.2006 08:15 Jan Martinek | skóre: 43 | blog: johny | Brno
    Rozbalit Rozbalit vše Re: python: pole <-> slovník
    V pythonu lze přímou cestou zkonvertovat list na dict pouze tehdy, jsou-li položky klíč-hodnota ve dvojicích (tuples). V tvém případě jsou na lichých pozicích klíče, na sudých hodnoty. Takže se vyberou liché, vyberou sudé, pak se zipnou a pak se to zkonvertuje:
    p = ['one', 1, 'two', 2, 'three', 3, 'four', 4]
    keys = p[0::2]    #liche
    values = p[1::2]  #sude
    zipped = zip(keys, values)
    slovnik = dict(zipped)
    slovnik
    {'four': 4, 'three': 3, 'two': 2, 'one': 1}
    
    příznivci one-linerů to mohou napsat takto:
    dict(zip(p[0::2], p[1::2]))
    
    12.5.2006 08:27 Jan Martinek | skóre: 43 | blog: johny | Brno
    Rozbalit Rozbalit vše Re: python: pole <-> slovník
    Aha, teď vidím, že ty hodnoty bereš z řetězce a přitom se to tam bude používat jako čísla, že? Tak by možná bylo dobré hodnoty rovnou překonvertovat. Buď
    values = map(int, p[1::2])  #sude
    
    nebo v případě toho one-lineru
    dict(zip(p[0::2], map(int, p[1::2])))
    
    12.5.2006 08:31 Jáchym Čepický | skóre: 29 | blog: U_Jachyma
    Rozbalit Rozbalit vše Re: python: pole <-> slovník
    to už je detail

    super! moc děkuju

    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.