Český statistický úřad (ČSÚ): Průměrná hrubá měsíční mzda ICT specialistů v roce 2025 meziročně vzrostla o 6 % na téměř 100 tisíc korun. Nejlépe placeni byli vývojáři softwaru. Dlouhodobým trendem zůstává nízké zastoupení žen, a to jak mezi specialisty, tak studenty těchto oborů.
Ochranný svaz autorský (OSA) připravuje žalobu na společnost Suno, která umožňuje generování hudby pomocí umělé inteligence (AI). ČTK to sdělil předseda představenstva OSA Roman Strejček. Suno podle něj bez souhlasu využívá k trénování svých modelů hudbu autorů, které svaz zastupuje. Nedávný investigativní materiál magazínu The Atlantic ukázal, že firmy jako Suno nebo Udio k trénování modelů používají rozsáhlé databáze obsahující miliony skladeb. V databázích, které časopis zveřejnil, lze dohledat i písně řady českých a slovenských umělců.
Byl publikován přehled dění a novinek z vývoje Asahi Linuxu, tj. Linuxu pro Apple Silicon. Vyřešen byl problém s macOS 27 Golden Gate. Vývoj lze podpořit na Open Collective a GitHub Sponsors.
EU dnešním dnem zavedla clo ve výši 3 eur na balíky nízké hodnoty dovážené ze zemí mimo EU. To zahrnuje širokou škálu výrobků běžně nakupovaných on-line, jako jsou oděvy, hračky, elektronika a další spotřební zboží v hodnotě až 150 EUR.
Vyšel Redmine 7.0, jeden z nejlepších open source ticketovacích systémů. Došlo k migraci na Rails 8, vylepšení UI/UX, Workflow, byla přidána podpora náhledu pro Microsoft Office a LibreOffice dokumenty, došlo k výkonnostním optimalizacím a přibylo spoustu dalších oprav a novinek. Více informací v oficiálním oznámení.
Nové číslo časopisu Raspberry Pi zdarma ke čtení: Raspberry Pi Official Magazine 166 (pdf).
Blíží se prázdniny a než se rozutečete k moři, je na čase se opět sejít na Virtuální Bastlírně - pravidelném setkání elektroniků, ajťáků, bastlířů a obecně nadšenců do techniky. Co si pro vás strahovští bastlíři připravili tentokrát? Určitě proberou blížící se Linux Days i další události. U softwaru se chvíli zdrží a poví si kupříkladu o tom, jak se zbavit Bambu Cloudu, ale nepřijít o možnost ovládat tiskárnu na dálku. Řeč dojde i na AI,
… více »Vývojáři postmarketOS vydali verzi 26.06 tohoto operačního systému pro chytré telefony vycházejícího z optimalizovaného a nakonfigurovaného Alpine Linuxu s vlastními balíčky. Přehled novinek v příspěvku na blogu. Na výběr jsou 4 uživatelská rozhraní: GNOME, KDE Plasma Mobile, Phosh a Sxmo.
Byla vydána nová verze 2.55.0 distribuovaného systému správy verzí Git. Přispělo 100 vývojářů, z toho 33 nových. Přehled novinek v příspěvku na blogu GitHubu a v poznámkách k vydání.
Craig Loewen na blogu Microsoftu oznámil veřejnou preview verzi WSL kontejnerů, tj. linuxových kontejnerů ve Windows Subsystem for Linux (WSL). Spouští se příkazem wslc.exe.
Tato funkce je vhodná zejména při vývoji a praktických pokusech s shellem. Není-li jí předán žádný argument, vrací seznam atributů v lokálním jmenném prostoru. Pokud předáte jako argument objekt, vrátí atributy tohoto objektu. Vrácený seznam je získáván ze slovníku __dict__ prohlíženého objektu. Funkce však nemusí zobrazit všechny položky slovníku. Při prohlížení atributů třídy, která je potomkem nějaké jiné třídy, vrátí dir() jména atributů rekurzivně, tj. včetně jmen rodiče.
>>> dir() # zobrazeni atributu lokalni mnoziny jmen
['__builtins__', '__doc__', '__name__', 'os']
>>> class trida:
... """Trida prikladu"""
... cislo = 7
...
>>> dir(trida) # zobrazeni atributu tridy
['__doc__', '__module__', 'cislo']
>>> trida.__dict__ # jako vyse, ale ze slovniku __dict__
{'__module__': '__main__', '__doc__': 'Trida prikladu', 'cislo': 7}
>>>
Přejímá dvě nekomplexní čísla a vrací n-tici jejich podílu a zbytku po celočíselném dělení. Parametry mohou být celá čísla nebo reálná čísla (jejich výpočet pak vypadá takto: (math.floor(a/b), a%b)), v případě smíšení typů se použijí standardní pravidla pro konverze. Předá-li se funkci komplexní argument, vyvolá DeprecationWarning.
Tato funkce slouží k sekvenčnímu procházení posloupnosti pomocí iterátorů. Parametr musí být sekvence nebo jiný objekt podporující "iteraci". Vráceným objektem je enumerate, který je potomkem iterator. Jeho metoda next() vrací další prvek posloupnosti jako n-tici s indexem a hodnotou. Enumerate se objevilo poprvé ve verzi 2.3 a je velmi vhodné k procházení posloupností pomocí cyklu for.
>>> seznam = [1, 2, 3, 4, 5, 6]
>>> for i in range(len(seznam)):
... print i, " -> ", seznam[i]
...
0 -> 1
1 -> 2
2 -> 3
3 -> 4
4 -> 5
5 -> 6
>>> for i,j in enumerate(seznam): # prochazeni seznamu pomoci enumerate
... print i, " -> ", j
...
0 -> 1
1 -> 2
2 -> 3
3 -> 4
4 -> 5
5 -> 6
>>> slovnik = {'a':1, 'b':2, 'c':3, 'd':4, 'e':5}
>>> for i in slovnik.keys():
... print i, " -> ", slovnik[i]
...
a -> 1
c -> 3
b -> 2
e -> 5
d -> 4
>>> for i, j in enumerate(slovnik): # slovniky je mozne tez prochazet
... print j, " -> ", i # ale pozor, klic a hodnota jsou oproti seznamu prohozene
...
a -> 0
c -> 1
b -> 2
e -> 3
d -> 4
>>>
Pozn.: Iterátory budeme probírat v některém z dalších dílů.
Prvním argumentem funkce je textový řetězec obsahující platný pythonský výraz; po zpracování vrací True nebo False podle toho, zda je výraz pravdivý či nikoliv. Nejsou-li zadány parametry globals a locals, je výraz vyhodnocen v prostředí, ze kterého byla funkce spuštěna. Globals a locals pak představují slovníky obsahující objekty prostředí, pro které je výraz vyhodnocován. Navíc má expression přístup ke všem builtins, takže se nemusí explicitně přiřazovat. Funkce navíc umožňuje spouštět kompilované výrazy (compile() - viz předchozí díl).
>>> x = 125
>>> eval('x >= 25 and x < 300')
True
>>> glob = globals() # ulozi slovnik globalnich jmen do promenne
>>> glob['x'] = 300 # a v teto promenne zmeni "promennou" x na 300
>>> eval('x >= 25 and x < 300',glob) # pouzije jako globals prom. glob
False
>>>
Execfile je příbuzná s příkazem exec a zároven má podobné použití jako import. Stejně jako exec provádí funkce execfile pythonské příkazy, rozdíl je však v tom, že tyto příkazy jsou uloženy v jiném souboru. Jméno tohoto souboru se předává jako textový řetězec prvnímu argumentu. Funkci lze využít jako alternativu k příkazu import. Nesmíme však zapomenout, že execfile neprovádí modulovou administraci. Znamená to, že se nevytvoří nový objekt modulu, ale provedou se pouze příkazy obsažené v souboru.
Soubor pokusny.txt:
print 'pokusny soubor'
for i in range(5):
print i
Kód ukázkového programu:
>>> execfile('pokusny.txt')
pokusny soubor
0
1
2
3
4
>>>
Globals a locals zde fungují stejně jako v předchozím případě.
Už podle názvu lze odvodit, že tato funkce otevírá soubor pro práci. Jméno souboru se specifikuje jako řetězec a je prvním parametrem. Navráceným objektem je objekt file. Parametr mode určuje, v jakém módu může být soubor otevřen, a předávané hodnoty jsou notoricky známé:
| 'r' | Mód čtení; jinak výchozí hodnota. |
| 'w' | Mód otevírající soubor pro zápis. Pokud soubor neexistuje, vytvoří jej. |
| 'a' | Mód otevírající soubor pro přidávání dat na konec. Obsah se nepřepíše. |
| 'r+' | Mód pro čtení a zápis, původní obsah nebude zničen. |
| 'w+' | Mód pro čtení a zápis, seřízne však původní soubor na nulovou délku - vytvoří v podstatě nový. |
| 'a+' | Mód pro čtení a přidávání na konec. |
| 'b' | Binární mód - nemá význam na unixových strojích. |
Argument bufsize nastavuje velikost bufferu: 0 - buffer se nepoužívá, 1 - řádkový buffer, všechny ostatní hodnoty nastavují velikost bufferu přibližně na svou hodnotu. Zadá-li se záporná hodnota, použije se velikost výchozí pro systém. To samé se stane, pokud parametr bufsize vynecháme.
File byl přidán ve verzi 2.2, jako jakýsi alias pro open(). Je to totiž mnohem přehlednější pro testování:
>>> f = open('soubor')
>>> isinstance(f,file) # prikaz je mnohem pruhlednejsi
True
>>>
Nástroje: Tisk bez diskuse
Tiskni
Sdílej: