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 16:55 | IT novinky

Libre Computer Project spustil na Kickstarteru kampaň na podporu svého prvního jednodeskového počítače s kódovým názvem Le Potato. Cena Le Potata s čtyřjádrovým 64bitovým ARM Cortex-A53 CPU a ARM Mali-450 GPU začíná na 25 dolarech.

Ladislav Hagara | Komentářů: 0
dnes 16:11 | IT novinky

Otevřená certifikační autorita Let's Encrypt oznámila, že vydala již přes 100 milionů certifikátů. Dle telemetrických dat (about:telemetry) anonymně odesílaných z webových prohlížečů Firefox organizaci Mozilla bylo při spuštění veřejné bety otevřené certifikační autority Let's Encrypt, v prosinci 2015, pomocí HTTPS stahováno 39,5 % webových stránek. Dnes je to téměř 58 %. Podrobnosti na stránce se statistikami.

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

Bylo vydáno (pdf) již devětapadesáté číslo stostránkového anglicky psaného časopisu MagPi věnovanému Raspberry Pi a projektům postaveným na tomto jednodeskovém počítači. K dispozici je také jako papírový časopis za 5,99 £.

Ladislav Hagara | Komentářů: 0
dnes 09:22 | Komunita

The Document Foundation vyhlásila soutěž o maskota svobodného kancelářského balíku LibreOffice. Návrhy lze předložit do 31. srpna. Autoři prvních tří návrhů získají věcné ceny (Slimbook KATANA Intel i5, Nextcloud box with Raspberry Pi 3 a Nitrokey Pro 3) [reddit].

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

Byla vydána nová verze 8.0.0 svobodného toolkitu pro počítačovou 3D grafiku, zpracování obrazu a vizualizaci VTK (Visualization Toolkit, Wikipedie). Z novinek vývojáři zdůrazňují VTK-m přinášející podporu mnohojádrových procesorů. Na vývoji VTK 8.0.0 se podílelo 79 vývojářů.

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

Eclipse Foundation oznámila vydání nové verze vývojového prostředí Eclipse. Eclipse 4.7 s kódovým označením Oxygen vychází rok po vydání verze 4.6 s kódovým označením Neon (zprávička) a přináší celou řadu novinek. Jejich představení také na YouTube.

Ladislav Hagara | Komentářů: 5
včera 23:33 | Zajímavý software

Před týdnem Lennart Poettering představil casync, tj. nástroj pro distribuci obrazů systémů. Dnes oficiálně představil mkosi, tj. nástroj pro generování těchto obrazů. Zdrojové kódy mkosi jsou k dispozici na GitHubu pod licencí LGPL-2.1.

Ladislav Hagara | Komentářů: 2
včera 16:00 | Bezpečnostní upozornění

Ve správci systému a služeb systemd, konkrétně v systemd-resolved, byla nalezena bezpečnostní chyba CVE-2017-9445. Útočník může vzdáleně shodit server nebo spustit libovolný příkaz.

Ladislav Hagara | Komentářů: 26
27.6. 11:33 | Pozvánky

Konference LinuxDays 2017 proběhne o víkendu 7. a 8. října v Praze v Dejvicích v prostorách FIT ČVUT. Konference OpenAlt 2017 proběhne o víkendu 4. a 5. listopadu na FIT VUT v Brně. Organizátoři konferencí vyhlásili CFP (LinuxDays, OpenAlt). Přihlaste svou přednášku nebo doporučte konference známým.

Ladislav Hagara | Komentářů: 1
27.6. 06:00 | Nová verze

Byla vydána verze 1.3.0 odlehčeného desktopového prostředí Lumina (Wikipedie, GitHub) postaveného nad toolkitem Qt. Z novinek lze zmínit nový motiv ikon nahrazující Oxygen (material-design-[light/dark]) nebo vlastní multimediální přehrávač (lumina-mediaplayer).

Ladislav Hagara | Komentářů: 2
Chystáte se pořídit CPU AMD Ryzen?
 (7%)
 (31%)
 (1%)
 (9%)
 (44%)
 (9%)
Celkem 860 hlasů
 Komentářů: 65, poslední 1.6. 19:16
    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: 317×
    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.