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 10:22 | Komunita

Minulý týden byla ze správce souborů (Files, Soubory, Nautilus) v GNOME odstraněna možnost spouštění aplikací. Po bouřlivé diskusi byla dnes tato možnost do správce souborů vrácena (commit).

Ladislav Hagara | Komentářů: 8
včera 22:44 | Nová verze

Ani ne po měsíci vývoje od vydání verze 2.10.0 byla vydána nová verze 2.10.2 svobodné aplikace pro úpravu a vytváření rastrové grafiky GIMP. Přehled novinek i s náhledy v oznámení o vydání. Opraveno bylo 44 chyb. Novinkou je podpora formátu HEIF (High Efficiency Image File Format) a dva nové filtry.

Ladislav Hagara | Komentářů: 15
včera 17:44 | Komunita

SFC (Software Freedom Conservancy) na svém blogu blahopřeje společnosti Tesla k prvnímu kroku k dodržování licence GPL. Tesla ve svých elektromobilech používá svobodný software. Změny ve zdrojovým kódech ale doteď veřejně nezveřejňovala. Změna nastala tento týden. Zdrojové kódy byly zveřejněny na GitHubu. Nejedná se zatím ale o kompletní odpovídající zdrojové kódy (CCS - complete corresponding source).

Ladislav Hagara | Komentářů: 13
19.5. 17:33 | Komunita

Společnost Purism informuje o aktuálním vývoji chytrého telefonu Librem 5, jenž by měl respektovat bezpečnost, svobodu a soukromí uživatelů. Telefon už umí telefonovat. Librem 5 by měl být k dispozici v lednu 2019. Předobjednat jej lze za 599 dolarů.

Ladislav Hagara | Komentářů: 28
19.5. 09:00 | Bezpečnostní upozornění

Společnost Qualys zveřejnila výsledky bezpečnostního auditu procps-ng, tj. balíčku s příkazy free, kill, pgrep, pidof, pkill, pmap, ps, pwdx, skill, slabtop, snice, sysctl, tload, top, uptime, vmstat, w a watch. Nalezeno bylo 7 bezpečnostních chyb (CVE-2018-1120, CVE-2018-1121, CVE-2018-1122, CVE-2018-1123, CVE-2018-1124, CVE-2018-1125 a CVE-2018-1126). Dvě z nich jsou zneužitelné k lokální eskalaci práv. Příslušné záplaty jsou již k dispozici v upstreamu.

Ladislav Hagara | Komentářů: 5
18.5. 06:44 | Nová verze

Byla vydána třiadvacátá alfa verze svobodné historické realtimové strategie 0 A.D. (Wikipedie). Kódový název této nejnovější verze je Ken Wood. Představení novinek v poznámkách k vydání a také na YouTube.

Ladislav Hagara | Komentářů: 3
18.5. 05:55 | Zajímavý článek

Tento týden se v Cambridge ve Velké Británii konal hackfest, který měl za cíl zlepšit výkon na GNOME postavených systémů na slabších počítačích. Hans de Goede například analyzoval spotřebu paměti jednotlivých komponent ve Fedora 28 Workstation na stroji s 2 GB RAM a pomocí kroků popsaných v článku Kde uspořit paměť ve Fedora Workstation na MojeFedora.cz snížil spotřebu paměti z 1,4 GB na 765 MB.

Ladislav Hagara | Komentářů: 10
17.5. 20:55 | Nová verze

Bram Moolenaar oznámil vydání verze 8.1 textového editoru Vim (Vi IMproved). Hlavní novinkou je integrovaný terminál.

Ladislav Hagara | Komentářů: 8
17.5. 16:55 | Nová verze

Bylo oznámeno vydání nové stabilní verze 1.27 a beta verze 1.28 open source textového editoru Atom (Wikipedie). Přehled novinek i s náhledy v příspěvku na blogu. Podrobnosti v poznámkách k vydání.

Ladislav Hagara | Komentářů: 6
17.5. 11:11 | Nová verze

Byla vydána verze 5.2 open source virtualizační platformy Proxmox VE (Proxmox Virtual Environment, Wikipedie) založené na Debianu. Přehled novinek v poznámkách k vydání a v informačním videu. Před měsícem slavil Proxmox VE 10 let (pdf).

Ladislav Hagara | Komentářů: 16
Používáte pro některé služby inetd?
 (33%)
 (24%)
 (42%)
Celkem 135 hlasů
 Komentářů: 4, poslední dnes 12:56
    Rozcestník

    Dotaz: Python - Jak vytvořit sezamy

    15.5.2015 19:19 Jakubysko
    Python - Jak vytvořit sezamy
    Přečteno: 384×
    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

    mika-talvinen avatar 15.5.2015 19:57 mika-talvinen | skóre: 23 | Plzeň
    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]
    
    mika-talvinen avatar 16.5.2015 11:20 mika-talvinen | skóre: 23 | Plzeň
    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.