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 01:00 | Komunita

    Debian dnes slaví 32 let. Ian Murdock oznámil vydání "Debian Linux Release" 16. srpna 1993.

    Ladislav Hagara | Komentářů: 7
    včera 17:44 | IT novinky

    Policisté zadrželi odsouzeného drogového dealera Tomáše Jiřikovského, který daroval ministerstvu spravedlnosti za tehdejšího ministra Pavla Blažka (ODS) bitcoiny v miliardové hodnotě, a zajistili i darovanou kryproměnu. Zadržení Jiřikovského může být podle ministerstva důležité k rozuzlení kauzy, která vypukla koncem května a vedla ke konci Blažka. Zajištění daru podle úřadu potvrzuje závěry dříve publikovaných právních

    … více »
    Ladislav Hagara | Komentářů: 6
    včera 13:44 | IT novinky

    Administrativa amerického prezidenta Donalda Trumpa jedná o možném převzetí podílu ve výrobci čipů Intel. Agentuře Bloomberg to řekly zdroje obeznámené se situací. Akcie Intelu v reakci na tuto zprávu výrazně posílily. Trump minulý týden označil Tana za konfliktní osobu, a to kvůli jeho vazbám na čínské společnosti, čímž vyvolal nejistotu ohledně dlouholetého úsilí Intelu o obrat v hospodaření. Po pondělní schůzce však prezident o šéfovi Intelu hovořil příznivě.

    Ladislav Hagara | Komentářů: 3
    včera 05:44 | IT novinky

    Společnost Purism stojící za linuxovými telefony a počítači Librem má nově v nabídce postkvantový šifrátor Librem PQC Encryptor.

    Ladislav Hagara | Komentářů: 10
    14.8. 18:00 | Nová verze

    VirtualBox, tj. multiplatformní virtualizační software, byl vydán v nové verzi 7.2. Přehled novinek v Changelogu. Vypíchnou lze vylepšené GUI.

    Ladislav Hagara | Komentářů: 0
    14.8. 14:11 | IT novinky

    Eric Migicovsky, zakladatel společnosti Pebble, v lednu oznámil, že má v plánu spustit výrobu nových hodinek Pebble s již open source PebbleOS. V březnu spustil předprodej hodinek Pebble Time 2 (tenkrát ještě pod názvem Core Time 2) za 225 dolarů s dodáním v prosinci. Včera představil jejich konečný vzhled (YouTube).

    Ladislav Hagara | Komentářů: 26
    14.8. 12:44 | Zajímavý software

    Byla oznámena nativní podpora protokolu ACME (Automated Certificate Management Environment) ve webovém serveru a reverzní proxy NGINX. Modul nginx-acme je zatím v preview verzi.

    Ladislav Hagara | Komentářů: 1
    14.8. 12:22 | Nová verze

    Vývojáři KDE oznámili vydání balíku aplikací KDE Gear 25.08. Přehled novinek i s náhledy a videi v oficiálním oznámení.

    Ladislav Hagara | Komentářů: 0
    13.8. 11:55 | IT novinky

    Společnost Perplexity AI působící v oblasti umělé inteligence (AI) podala nevyžádanou nabídku na převzetí webového prohlížeče Chrome internetové firmy Google za 34,5 miliardy dolarů (zhruba 723 miliard Kč). Informovala o tom včera agentura Reuters. Upozornila, že výše nabídky výrazně převyšuje hodnotu firmy Perplexity. Společnost Google se podle ní k nabídce zatím nevyjádřila.

    Ladislav Hagara | Komentářů: 5
    13.8. 04:33 | Bezpečnostní upozornění

    Intel vydal 34 upozornění na bezpečnostní chyby ve svých produktech. Současně vydal verzi 20250812 mikrokódů pro své procesory řešící 6 bezpečnostních chyb.

    Ladislav Hagara | Komentářů: 0
    Kolik tabů máte standardně otevřeno ve web prohlížeči?
     (52%)
     (19%)
     (4%)
     (5%)
     (3%)
     (1%)
     (1%)
     (17%)
    Celkem 400 hlasů
     Komentářů: 23, poslední 4.8. 13:01
    Rozcestník

    Dotaz: Hledani prvku v poli - python

    28.11.2009 00:43 array
    Hledani prvku v poli - python
    Přečteno: 1337×
    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.