Portál AbcLinuxu, 13. května 2025 18:33

Dotaz: Hledani prvku v poli - python

28.11.2009 00:43 array
Hledani prvku v poli - python
Přečteno: 1334×
Odpovědět | Admin
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?
Nástroje: Začni sledovat (2) ?Zašle upozornění na váš email při vložení nového komentáře.

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
Odpovědět | | Sbalit | Link | Blokovat | Admin
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?
Weblate - překládání přes web | Gammu SMSD - posílání SMS | Blog
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
Odpovědět | | Sbalit | Link | Blokovat | Admin
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
Odpovědět | | Sbalit | Link | Blokovat | Admin
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, (c) 1999-2007 Stickfish s.r.o.