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 12:55 | Nová verze

    CiviCRM (Wikipedie) bylo vydáno v nové verzi 6.14.0. Podrobnosti o nových funkcích a opravách najdete na release stránce. CiviCRM je robustní open-source CRM systém navržený speciálně pro neziskové organizace, spolky a občanské iniciativy. Projekt je napsán v jazyce PHP a licencován pod GNU Affero General Public License (AGPLv3). Český překlad má nyní 45 % přeložených řetězců a přibližuje se milníku 50 %. Potřebujeme vaši pomoc, abychom se dostali dál. Pokud máte chuť přispět překladem nebo korekturou, přidejte se na platformu Transifex.

    jardaIT | Komentářů: 0
    dnes 12:22 | Bezpečnostní upozornění

    Další lokální zranitelností Linuxu je ssh-keysign-pwn. Uživatel si může přečíst obsah souborů, ke kterým má právo ke čtení pouze root, například soubory s SSH klíči nebo /etc/shadow. V upstreamu již opraveno [oss-security mailing list].

    Ladislav Hagara | Komentářů: 0
    včera 17:22 | Komunita

    Singularity (YouTube) je nejnovější otevřený film od Blender Studia. Jedná se o jejich první 4K HDR film.

    Ladislav Hagara | Komentářů: 0
    včera 16:55 | Zajímavý software

    Vyšla hra Život Není Krásný: Poslední Exekuce (Steam, ProtonDB). Kreslená point & click adventura ze staré školy plná černého humoru a nekorektního násilí. Vžijte se do role zpustlého exekutora Vladimíra Brehowského a projděte s ním jeho poslední pracovní den. Hra volně navazuje na sérii Život Není Krásný.

    Ladislav Hagara | Komentářů: 22
    včera 14:00 | Zajímavý projekt

    Společnost Red Hat představila Fedora Hummingbird, tj. linuxovou distribuci s nativním kontejnerovým designem určenou pro vývojáře využívající AI agenty.

    Pinhead | Komentářů: 6
    včera 02:22 | Zajímavý software

    Hru The Legend of Zelda: Twilight Princess od společnosti Nintendo si lze nově díky projektu Dusklight (původně Dusk) a reverznímu inženýrství zahrát i na počítačích a mobilních zařízeních. Vyžadována je kopie původní hry (textury, modely, hudba, zvukové efekty, …). Ukázka na YouTube. Projekt byl zahájen v srpnu 2020.

    Ladislav Hagara | Komentářů: 0
    včera 01:11 | Nová verze

    Byla vydána nová major verze 29.0 programovacího jazyka Erlang (Wikipedie) a související platformy OTP (Open Telecom Platform, Wikipedie). Detailní přehled novinek na GitHubu.

    Ladislav Hagara | Komentářů: 0
    13.5. 21:22 | Bezpečnostní upozornění

    Po zranitelnostech Copy Fail a Dirty Frag přichází zranitelnost Fragnesia. Další lokální eskalace práv na Linuxu. Zatím v upstreamu neopravena. Přiřazeno ji bylo CVE-2026-46300.

    Ladislav Hagara | Komentářů: 1
    13.5. 14:00 | Komunita

    Sovereign Tech Agency (Wikipedie) prostřednictvím svého fondu Sovereign Tech Fund podpoří KDE částkou 1 285 200 eur.

    Ladislav Hagara | Komentářů: 11
    13.5. 12:55 | IT novinky

    Google na včerejší akci The Android Show | I/O Edition 2026 (YouTube) představil celou řadu novinek: Gemini Intelligence, notebooky Googlebook, novou generaci Android Auto, …

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

    Dotaz: Hledani prvku v poli - python

    28.11.2009 00:43 array
    Hledani prvku v poli - python
    Přečteno: 1373×
    Ahoj, mam problem s hledanim prvku v poli (v pythonu). Kdyz vytvorim takoveto pole, hledani funguje:
    mmm = ( ['a', 'b', 'c'] )
    i = mmm.index('b')	
    print i
    vrati 1

    ale kdyz vytvorim takoveto pole:
    mmm = ( ['a', 'b', 'c'], ['d', 'e', 'f'] )
    i = mmm.index('b')	
    print i
    nejde to:
    Traceback (most recent call last):
      File "pole.py", line 25, in <module>
        i = mmm.index('b')	
    ValueError: tuple.index(x): x not in list
    
    Jak se da prohledavat takoveto pole?

    Odpovědi

    28.11.2009 08:54 Michal Čihař | skóre: 61 | blog: Bláboly | Praha
    Rozbalit Rozbalit vše Re: Hledani prvku v poli - python
    Pro začátek proč první funguje:

    ( ['a', 'b', 'c'] ) == ['a', 'b', 'c']

    A co si představuješ, že by to mělo v druhém případě vrátit?
    28.11.2009 12:51 array
    Rozbalit Rozbalit vše Re: Hledani prvku v poli - python
    >>> mmm = ( ['a', 'b', 'c'], ['d', 'e', 'f'] )
    >>> print mmm[1]
    ['d', 'e', 'f']
    >>> print mmm[1][1]
    e
    Predstavoval bych si, ze to vrati to [1][1].
    2.12.2009 18:58 Lithius | skóre: 14
    Rozbalit Rozbalit vše Re: Hledani prvku v poli - python
    Tak jednoduse, pokud jde o Touple, prochazej jej v cyklu a v kazdem prvku (tedy seznamu) nech vyhledat to co potrebujes.
    2.12.2009 20:28 l4m4
    Rozbalit Rozbalit vše Re: Hledani prvku v poli - python
    Nemusíš nic procházet v cyklu, od toho jsou v Pythonu comprehensions, viz moje řešení dole. Pokud chceš jen první výskyt, použiješ kulaté iterátorové závorky namísto hranatých seznamových a vezmeš první prvek výsledku (a ošetříš IndexError, když se to nenajde), takže se to po nalezení prvního výskytu zastaví.
    28.11.2009 11:03 12345 | skóre: 41 | blog:
    Rozbalit Rozbalit vše Re: Hledani prvku v poli - python
    Toto je list obsahující prvky a, b a c:
    mmm = ( ['a', 'b', 'c'] )
    
    Jde o obyčejné pole (list).

    Toto je 1-tuple obsahující list, který zase obsahuje prvky a, b a c:
    mmm = ( ['a', 'b', 'c'], )
    
    Jde o „pole polí“ (přesněji tuple listů).

    A konečně toto je 2-tuple obsahující dva listy s prvky a, b, c, resp. d, e, f:
    mmm = ( ['a', 'b', 'c'], ['d', 'e', 'f'] )
    
    Opět tuple listů.

    Jestli chceš funkci na rekurzivní prohledávání polí, budeš si ji muset napsat. A, jak psal Michal Čihař, je otázkou, co by tak asi měla vracet.
    28.11.2009 15:56 l4m4
    Rozbalit Rozbalit vše Re: Hledani prvku v poli - python
    Jak je to přesně s datovými typy už vysvětlil Víťa Šmíd, takže jen takový příklad:
    >>> a, b = [], []
    >>> c = [a,b]
    >>> a.extend([b,c])
    >>> b.extend([a,c])
    
    Jak by sis asi představoval, že tam bude rekursivní index() fungovat? Co má přesně vrátit c.index(c)? Nekonečné pole? Má to hledat nejdřív do hloubky nebo do šířky? Je zjevné, že obecné rekursivní prohledávání od index() čekat nelze, takže chceš-li ho, musíš za daných předpokladů vlastnostech těch dat napsat.

    Např. toto je seznam všech dvojic indexů, kde se 'a' vyskytuje v tvém mmm:
    [(x[0],x[1].index('a')) for x in enumerate(mmm) if 'a' in x[1]]
    

    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.