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

    3D software Blender byl vydán ve verzi 4.5 s prodlouženou podporou. Podrobnosti v poznámkách k vydání. Videopředstavení na YouTube.

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

    Open source webový aplikační framework Django slaví 20. narozeniny.

    Ladislav Hagara | Komentářů: 0
    včera 16:11 | Komunita

    V Brestu dnes začala konference vývojářů a uživatelů linuxové distribuce Debian DebConf25. Na programu je řada zajímavých přednášek. Sledovat je lze online.

    Ladislav Hagara | Komentářů: 0
    včera 11:33 | IT novinky

    Před 30 lety, tj. 14. července 1995, se začala používat přípona .mp3 pro soubory s hudbou komprimovanou pomocí MPEG-2 Audio Layer 3.

    Ladislav Hagara | Komentářů: 26
    včera 10:55 | IT novinky

    Výroba 8bitových domácích počítačů Commodore 64 byla ukončena v dubnu 1994. Po více než 30 letech byl představen nový oficiální Commodore 64 Ultimate (YouTube). S deskou postavenou na FPGA. Ve 3 edicích v ceně od 299 dolarů a plánovaným dodáním v říjnu a listopadu letošního roku.

    Ladislav Hagara | Komentářů: 20
    13.7. 17:55 | Zajímavý projekt

    Společnost Hugging Face ve spolupráci se společností Pollen Robotics představila open source robota Reachy Mini (YouTube). Předobjednat lze lite verzi za 299 dolarů a wireless verzi s Raspberry Pi 5 za 449 dolarů.

    Ladislav Hagara | Komentářů: 17
    11.7. 16:44 | Komunita

    Dnes v 17:30 bude oficiálně vydána open source počítačová hra DOGWALK vytvořena v 3D softwaru Blender a herním enginu Godot. Release party proběhne na YouTube od 17:00.

    Ladislav Hagara | Komentářů: 3
    11.7. 14:55 | Humor

    McDonald's se spojil se společností Paradox a pracovníky nabírá také pomocí AI řešení s virtuální asistentkou Olivii běžící na webu McHire. Ian Carroll a Sam Curry se na toto AI řešení blíže podívali a opravdu je překvapilo, že se mohli přihlásit pomocí jména 123456 a hesla 123456 a získat přístup k údajům o 64 milionech uchazečů o práci.

    Ladislav Hagara | Komentářů: 16
    11.7. 00:11 | Nová verze

    Byla vydána (𝕏) červnová aktualizace aneb nová verze 1.102 editoru zdrojových kódů Visual Studio Code (Wikipedie). Přehled novinek i s náhledy a videi v poznámkách k vydání. Ve verzi 1.102 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.

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

    Byla vydána nová verze 2.4.64 svobodného multiplatformního webového serveru Apache (httpd). Řešeno je mimo jiné 8 bezpečnostních chyb.

    Ladislav Hagara | Komentářů: 4
    Jaký je váš oblíbený skriptovací jazyk?
     (59%)
     (26%)
     (7%)
     (3%)
     (1%)
     (1%)
     (4%)
    Celkem 397 hlasů
     Komentářů: 16, poslední 8.6. 21:05
    Rozcestník

    Dotaz: Hledani prvku v poli - python

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