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 02:22 | Nová verze

    Společnost Murena představila (YouTube) novou verzi 4.0 mobilního operačního systému /e/OS (Wikipedie) založeného na Androidu a LineageOS bez aplikací a služeb od Googlu.

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

    V Arch User Repository (AUR) bylo kompromitováno přes 400 opomíjených balíčků (jejich seznam). Útočník do nich začlenil škodlivý npm balíček atomic-lockfile, který krade citlivá data uživatelů. Publikována byla předběžná analýza spouštěného malwaru deps.

    Ladislav Hagara | Komentářů: 7
    včera 11:33 | Nová verze

    Homebrew, správce balíčků nejen pro macOS, byl vydán ve verzi 6.0.0 (seznam změn). Hlavními novinkami jsou bezpečnostní mechanismus tap trust kvůli důvěryhodnosti závislostí, vylepšení sandboxingu na Linuxu, interní JSON API nebo zlepšení výkonu.

    |🇵🇸 | Komentářů: 0
    včera 03:33 | Bezpečnostní upozornění

    Byla nalezena a 9. června opravena kritická zranitelnost ve FreeBSD v Kernel TLS (KTLS). Pojmenována byla Bumsrakete (FreeBSD-SA-26:26.ktls, CVE-2026-45257). Lokální neprivilegovaný uživatel může přepisovat soubory, ke kterým má právo pouze pro čtení. Přepsáním setuid binárky a jejím spuštěním může získat roota. Na všech verzích od verze 13.0 vydané v dubnu 2021.

    Ladislav Hagara | Komentářů: 2
    11.6. 14:11 | Komunita

    Vývojáři open source operačního systému ReactOS (Wikipedie), jehož cílem je kompletní binární kompatibilita s aplikacemi a ovladači pro Windows, se na síti 𝕏 pochlubili, že ReactOS zvládne počítačovou hru Half-Life.

    Ladislav Hagara | Komentářů: 4
    11.6. 10:44 | Nová verze

    Byla vydána nová verze 4.8 multiplatformního integrovaného vývojového prostředí (IDE) pro rychlý vývoj aplikaci (RAD) ve Free Pascalu Lazarus (Wikipedie). Využíván je Free Pascal Compiler (FPC) 3.2.2.

    Ladislav Hagara | Komentářů: 0
    11.6. 04:44 | Nová verze

    Apple container dospěl do verze 1.0.0. Jedná se o open source nástroj pro spouštění linuxových kontejnerů na macOS postavený nad containerization. Napsaný je v programovacím jazyce Swift a optimalizovaný pro Apple silicon.

    Ladislav Hagara | Komentářů: 5
    11.6. 03:33 | Nová verze

    Bylo vydáno Eclipse IDE 2026-06 aneb Eclipse 4.40. Představení novinek tohoto integrovaného vývojového prostředí také na YouTube.

    Ladislav Hagara | Komentářů: 0
    10.6. 15:44 | Zajímavý software

    Asterinas (GitHub) je v Rustu napsané jádro operačního systému poskytující s jádrem Linux kompatibilní ABI. Vydána byla verze 0.18.0. První distribucí postavenou nad jádrem Asterinas je Asterinas NixOS. Nejedná se o oficiální projekt NixOS a nemá nic společného s NixOS Foundation.

    Ladislav Hagara | Komentářů: 2
    10.6. 13:22 | Zajímavý článek

    Podrobně byla rozebrána kritická zranitelnost v nf_tables (CVE-2026-23111). Další lokální eskalace práv na Linuxu. V upstreamu byla zranitelnost již v únoru opravena. Ve zdrojovém kódu stačilo odstranit 1 vykřičník.

    Ladislav Hagara | Komentářů: 1
    Které desktopové prostředí na Linuxu používáte?
     (11%)
     (8%)
     (2%)
     (15%)
     (31%)
     (3%)
     (6%)
     (3%)
     (16%)
     (26%)
    Celkem 1887 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník


    Dotaz: Python - Jak vytvořit sezamy

    15.5.2015 19:19 Jakubysko
    Python - Jak vytvořit sezamy
    Přečteno: 472×
    Zdravím. Potřeboval bych poradit od zdejších profíků. Nevím si rady, jak vytvořit z jednoho seznamu dva seznamy.

    Z tohoto seznamu
    seznam_a = ["1", "A","2", "B","3", "C"]
    potřebuji vytvořit
    novy_seznam_a = ["1","2","3"]
    novy_seznam_b = ["A","B","C"]
    Pomůže prosím někdo ?

    Řešení dotazu:


    Odpovědi

    xxxxxx avatar 15.5.2015 19:57 xxxxxx | skóre: 23
    Rozbalit Rozbalit vše Re: Python - Jak vytvořit sezamy
    No tak úplně jednoduše to lze udělat třeba cyklem:
    novy_seznam_a = []
    novy_seznam_b = []
    
    for i in range(len(seznam_a)):
        if i%2 == 0:
            novy_seznam_a.append(seznam_a[i])
        else:
            novy_seznam_b.append(seznam_a[i])
    
    
    Ale to jen pokud se opravdu střídají ty prvky "a - b - a - b ...".

    Vždy pomůže napsat, o co se snažíte, do nějakého většího celku lze třeba použít vhodnější řešení.
    Řešení 2× (⧠ A = 0, mimi.vx)
    15.5.2015 20:36 NN
    Rozbalit Rozbalit vše Re: Python - Jak vytvořit sezamy
    seznam_b = seznam_a[::2]
    seznam_c = seznam_a[1::2]
    
    xxxxxx avatar 16.5.2015 11:20 xxxxxx | skóre: 23
    Rozbalit Rozbalit vše Re: Python - Jak vytvořit sezamy
    Díky, tohle jsem, přiznám se, nevěděl. Pro tazatele by se potom mohl hodit tento odkaz.
    18.5.2015 09:42 map
    Rozbalit Rozbalit vše Re: Python - Jak vytvořit sezamy
    This is the most pythonic answer.
    15.5.2015 21:36 source
    Rozbalit Rozbalit vše Re: Python - Jak vytvořit sezamy
    Pro obecnější řešení- předpokládám, že 1. seznam má vyjmout čísla a 2. seznam písmena by mohlo být možné testovat jednotlivé prvky na to, jestli je to číslo. A ostatní házet do druhé. Viz ten for cyklus výše, ale s jinou podmínkou.
    15.5.2015 22:26 Jakubysko
    Rozbalit Rozbalit vše Re: Python - Jak vytvořit sezamy
    To co napsal NN je fakt super, ale v mém případě potřebuji cyklus, jenže výše uvedený mi taky nevyhovuje, jelikož bych potřeboval tu proměnnou "i" v každém kroku mít navýšenou pouze o "i=i+1". Nešlo by místo té podmínky říct tomu cyklu aby načítál prvky na přeskáčku ? V bash se to myslím děla takto "for ((i=0 ; i<total ; i+=2))". Díky
    16.5.2015 10:01 Delaunay | skóre: 17 | blog:
    Rozbalit Rozbalit vše Re: Python - Jak vytvořit sezamy
    Takovou definici cyklu lze snadno zapsat jako range(0, total, 2), tzn. cely cyklus by vypadal takto:
    for i in range(0, len(seznam_a), 2):
      novy_seznam_a.append(seznam_a[(i / 2) * 2])
      try:
        novy_seznam_b.append(seznam_a[i + 1])
      except IndexError:
        pass
    
    Pokud ale musí mít vstupní seznam sudý počet prvků, tak není nutné maskovat IndexError výjimku.
    16.5.2015 11:00 johniez | skóre: 17 | blog: xyz | Praha
    Rozbalit Rozbalit vše Re: Python - Jak vytvořit sezamy
    (i / 2) * 2 ma nejaky duvod? Vzdyt i bude vzdy sude, ne?
    16.5.2015 14:32 Delaunay | skóre: 17 | blog:
    Rozbalit Rozbalit vše Re: Python - Jak vytvořit sezamy
    Nemá důvod, zůstalo tam nedopatřením. Správně má samozřejmě být:
    novy_seznam_a.append(seznam_a[i])
    
    17.5.2015 11:41 Jakubysko
    Rozbalit Rozbalit vše Re: Python - Jak vytvořit sezamy
    Díky všem za pomoc.
    rADOn avatar 18.5.2015 17:39 rADOn | skóre: 44 | blog: bloK | Praha
    Rozbalit Rozbalit vše Re: Python - Jak vytvořit sezamy
    Takhle to pisu ceckari a podobna verbez, NN na to sel lepe :-)
    for n, i, j in zip(range(len(a[::2])), a[::2], a[1::2]):
        …
    
    "2^24 comments ought to be enough for anyone" -- CmdrTaco
    18.5.2015 21:50 Delaunay | skóre: 17 | blog:
    Rozbalit Rozbalit vše Re: Python - Jak vytvořit sezamy
    Nice one :-) Céčková a podobná verbež sleduje také výkon a paměťovou náročnost. Tvorbu vymazlených write-only a spolehlivě neoptimálních konstrukcí přenechává python elitě :-)
    19.5.2015 09:56 logik
    Rozbalit Rozbalit vše Re: Python - Jak vytvořit sezamy
    Tak ono to je zapsaný ne úplně nejlíp (tam má bejt enumerate, viz níž), ale jinak Ti garantuju, že ve výsledku si to překladač zoptimalizuje úplně stejně. Spíše lépe, protože narozdíl od C-like řešení to vlastně vůbec nepotřebuje konstruovat nějakej seznam.

    A pro pythonistu to není write-only, čitelné je to dost, jen musíš bejt trochu zvyklej na pythoní přístup.
    19.5.2015 09:58 logik
    Rozbalit Rozbalit vše Re: Python - Jak vytvořit sezamy
    PS: A i když kompilátor nebude optimální a nové seznamy vytvoří, tak ho vytvoří "najednou", a ne v X atomických krocích, tedy daleko rychleji.
    rADOn avatar 19.5.2015 10:50 rADOn | skóre: 44 | blog: bloK | Praha
    Rozbalit Rozbalit vše Re: Python - Jak vytvořit sezamy
    Jsem to nechtel komplikovat a jen ukazat ze iteraci pres ciselnej index jde v pajtnu vetsinou napsat lip. Nekde ve standartni knihovne (v itertools?) je varianta zip() ktery nekonstruuje novy seznam ale vrati iterator. A chrono to ma jeste lip s tim enumeratorem…
    "2^24 comments ought to be enough for anyone" -- CmdrTaco
    19.5.2015 01:01 chrono
    Rozbalit Rozbalit vše Re: Python - Jak vytvořit sezamy
    Prípadne
    for n, (i, j) in enumerate(zip(a[::2], a[1::2])):

    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.