Hudební přehrávač Amarok byl vydán v nové major verzi 3.0 postavené na Qt5/KDE Frameworks 5. Předchozí verze 2.9.0 vyšla před 6 lety a byla postavená na Qt4. Portace Amaroku na Qt6/KDE Frameworks 6 by měla začít v následujících měsících.
Byla vydána nová verze 2.45.0 distribuovaného systému správy verzí Git. Přispělo 96 vývojářů, z toho 38 nových. Přehled novinek v příspěvku na blogu GitHubu a v poznámkách k vydání. Vypíchnout lze počáteční podporu repozitářů, ve kterých lze používat SHA-1 i SHA-256.
Před 25 lety, ve čtvrtek 29. dubna 1999, byla spuštěna služba "Úschovna".
Byla vydána nová verze 24.04.28 s kódovým názvem Time After Time svobodného multiplatformního video editoru Shotcut (Wikipedie) a nová verze 7.24.0 souvisejícího frameworku MLT Multimedia Framework. Nejnovější Shotcut je vedle zdrojových kódů k dispozici také ve formátech AppImage, Flatpak a Snap.
Byla vydána verze 5.30 dnes již open source operačního systému RISC OS (Wikipedie).
V aktuálním příspěvku na blogu počítačové hry Factorio (Wikipedie) se vývojář s přezývkou raiguard rozepsal o podpoře Linuxu. Rozebírá problémy a výzvy jako přechod linuxových distribucí z X11 na Wayland, dekorace oken na straně klienta a GNOME, změna velikosti okna ve správci oken Sway, …
Rakudo (Wikipedie), tj. překladač programovacího jazyka Raku (Wikipedie), byl vydán ve verzi #171 (2024.04). Programovací jazyk Raku byl dříve znám pod názvem Perl 6.
Společnost Epic Games vydala verzi 5.4 svého proprietárního multiplatformního herního enginu Unreal Engine (Wikipedie). Podrobný přehled novinek v poznámkách k vydání.
Byl vydán Nextcloud Hub 8. Představení novinek tohoto open source cloudového řešení také na YouTube. Vypíchnout lze Nextcloud AI Assistant 2.0.
mmm = ( ['a', 'b', 'c'] ) i = mmm.index('b') print ivrati
1
ale kdyz vytvorim takoveto pole:
mmm = ( ['a', 'b', 'c'], ['d', 'e', 'f'] ) i = mmm.index('b') print inejde to:
Traceback (most recent call last): File "pole.py", line 25, in <module> i = mmm.index('b') ValueError: tuple.index(x): x not in listJak se da prohledavat takoveto pole?
( ['a', 'b', 'c'] ) == ['a', 'b', 'c']
A co si představuješ, že by to mělo v druhém případě vrátit?
>>> mmm = ( ['a', 'b', 'c'], ['d', 'e', 'f'] ) >>> print mmm[1] ['d', 'e', 'f'] >>> print mmm[1][1] ePredstavoval bych si, ze to vrati to [1][1].
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 list
y 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.
>>> 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]]
Tiskni Sdílej: