Na crowdsourcingové platformě Crowd Supply byla spuštěna kampaň na podporu open source biometrického monitoru ve tvaru hodinek HealthyPi Move. Cena je 249 dolarů a plánovaný termín dodání listopad letošního roku.
Firma Murena představila /e/OS verze 2.0. Jde o alternativní sestavení Androidu bez aplikací Google. Mezi novinkami je podrobnější nastavení ochrany soukromí před sledováním aplikacemi. Murena prodává několik smartphonů s předinstalovaným /e/OS (Fairphone, repasovaný Google Pixel 5).
Do 30. května lze v rámci akce Warhammer Skulls 2024 získat na Steamu zdarma hru Warhammer 40,000: Gladius - Relics of War.
HelenOS (Wikipedie), tj. svobodný operační systém českého původu založený na architektuře mikrojádra, byl vydán ve verzi 0.14.1. Přehled novinek v poznámkách k vydání. Vypíchnou lze nabídku Start. Videopředstavení na YouTube.
BreadboardOS je firmware pro Raspberry Pi Pico (RP2040) umožňující s tímto MCU komunikovat pomocí řádkového rozhraní (CLI). Využívá FreeRTOS a Microshell.
Vývojáři KDE oznámili vydání balíku aplikací KDE Gear 24.05. Přehled novinek i s náhledy a videi v oficiálním oznámení. Do balíku se dostalo 5 nových aplikací: Audex, Accessibility Inspector, Francis, Kalm a Skladnik.
Byla vydána (𝕏) nová verze 18.0.0 open source webového aplikačního frameworku Angular (Wikipedie). Přehled novinek v příspěvku na blogu.
V neděli 26. května lze navštívit Maker Faire Rychnov nad Kněžnou, festival plný workshopů, interaktivních činností a především nadšených a zvídavých lidí.
Byla vydána nová stabilní verze 3.20.0, tj. první z nové řady 3.20, minimalistické linuxové distribuce zaměřené na bezpečnost Alpine Linux (Wikipedie) postavené na standardní knihovně jazyka C musl libc a BusyBoxu. Z novinek lze vypíchnou počáteční podporu 64bitové architektury RISC-V.
Mám funkci v Pythonu:
def get_template(template_file): """Get a file containing a template. Return its content as a string.""" try: return open(template_file, 'r').read() except IOError: print "Error: Cannot read the file containing the template."
Na webu Pythonu se ale (v HOWTO Idioms and Anti-Idioms in Python) uvádí jako ne zcela správný příklad:
def get_status(file): try: return open(file).readline() except (IOError, OSError): print "file not found" sys.exit(1)
Mimochodem, proč je tam OSError
?
U příkladu níže se píše, že ideální a že výjimka se má řešit v místě volání (což nechci).
def get_status(file): fp = open(file) try: return fp.readline() finally: fp.close()
Jak je to v mém kódu s uzavíráním souboru? Nemám do svého try
bloku vnořit ještě jeden s větví finally
?
Řešení dotazu:
Nikdo neodpovídá, tak to zkusím. Ale moc nevím, v čem je jádro pudla, tak to nějak vágně okomentuju:
Jestliže chci přečíst soubor, tak chci buď jeho obsah nebo vyhozenou výjimku. Ten první příklad se mi proto moc nelíbí, protože když něco selže, tak jen vypíše nějaký řetězec na obrazovku, ale vrátí None. Navíc, nevypíšou se podrobnosti o chybě. Zavírat soubor nemusíš.
Ve druhém (a třetím) příkladě se přepisuje klíčové slovo „file“, což není dobrý nápad. Naopak, je spíš zvykem používat file místo open (jsou to synonyma).
Druhý příklad: Kdy se v tomto případě může vyskytnout OSError, to nevím. Dám se podat.
Třetí příklad považuju za zrádný. Někdy vrátí None, někdy vyhodí výjimku,
No prostě, já bych to psal takhle
def readfile(fn): return file(fn).read()
A na to bych vlastně ani nepsal funkci. Ale to je do značné míry otázka vkusu a taky toho, jak moc si chceš všechno ošetřit sám.
Imho ten první příklad je spíš špatně proto, že ověřuje existenci souboru pomocí vyjímky.To by se spíš mělo řešit např pomocí os.path ...
os.path
mi nevyřeší případ, když během čtení něco ten soubor smaže. Takže tam mám dát obojí?
Je to tak jak řikáš - os.path spoustu věcí nevyřeší. Jako špatný příklad je to podle mě uvedeno právě z toho důvodu, že se tím ověřuje existence souboru, na což jsou ale jinačí nástroje. Pro jiné případy může být samořejmě použití vyjímek adekvátní.
No a? Pokud je ten soubor pro funkčnost nutný, pak je výjimka na místě. Pokud má aplikace počítat s tím, že soubor tam být nemusí, pak bylo by lepší použít os.path.isfile().
Pokud je soubor nutný, tak bych vyhodil svojí vyjímku:
if not os.path.exists("soubor"): raise NejakaMojeVyjimka(.......)
To je jedna třída a několik řádků kódu navíc. Záleží na rozsahu a komplexnosti projektu, jestli je nutné mít pro všechno vlastní výjimky.
Stejně tak pak musíš ošetřit i výjimku z open()/file(), protože ten soubor mohl v čase mezi exists() a open() někdo smazat
Záleží na rozsahu a komplexnosti projektu...
Několik set řádků, možná to poslouží jako backend pro GUI nebo jednoduchou webovou aplikaci.
Jestliže chci přečíst soubor, tak chci buď jeho obsah nebo vyhozenou výjimku. Ten první příklad se mi proto moc nelíbí, protože když něco selže, tak jen vypíše nějaký řetězec na obrazovku, ale vrátí None. Navíc, nevypíšou se podrobnosti o chybě.
OK, co s tím? sys.exit
? Ale to je nevhodné při použití jako knihovny ve frameworku...
Zavírat soubor nemusíš.
Díky.
Ve druhém (a třetím) příkladě se přepisuje klíčové slovo „file“, což není dobrý nápad. Naopak, je spíš zvykem používat file místo open (jsou to synonyma).
Ten kód je z webu Pythonu...
Třetí příklad považuju za zrádný. Někdy vrátí None, někdy vyhodí výjimku,...
Taky si myslím, ale autor toho HOWTO píše, že to má být ošetřeno v místě volání funkce.
OK, co s tím?
sys.exit
? Ale to je nevhodné při použití jako knihovny ve frameworku..
Tak mohlo by to třeba vyhazovat výjimku, že Nebo vracet None. Ale výjimka bude lepší, především může nést informaci o chybě; to tam pak ani žádné try-except nemusíš dávat. Knihovna by asi také neměla sama od sebe něco vypisovat na jakýkoliv standardní výstup, stejně jako by neměla exitovat (pokud to ovšem nemá být smysl knihovny).
Soubor se ti uzavře sám, jakmile se garbage collector bude chtít zbavit instance file. To může být kdykoliv a může to případně i vypisovat nějaké warningy nebo tak něco, což by mohlo být dost nečekané a matoucí, takže občas se soubory uzavírají v bloku finally.
Mimochodem, pokud řešíš takové detaily už u obyčejného čtení souboru, co teprve děláš při rozhodování o celkovém designu aplikace?
Tak mohlo by to třeba vyhazovat výjimku, že
Bingo!
Mimochodem, pokud řešíš takové detaily už u obyčejného čtení souboru, co teprve děláš při rozhodování o celkovém designu aplikace?
Ladím si styl. ^_^
Jestliže ty výjimky odchytávat nepotřebuješ, tak to nedělej. Mnohem lépe se to pak ladí, protože backtrace ukáže spoustu důležitých informací. Nejhorší je, když někdo odchytne vyjimku a dá tam print "ERROR" a ukončí program.
None
.
Informace, kde přesně je chyba, by ale měla být součástí té výjimky, ne? Obecně platí, že by měla být přísně dodržena pravidla ošetřování chyb - buď VŠECHNO ve frameworku pouští/vyhazuje výjimku, nebo všechno vrací/nastavuje nějaký předdefinovaný chybový stav (None, -1, ...). V tomhle případě zřejmě metoda předpokládá, že template existuje a jeho neexistence je tedy vyjímečným stavem (odtud výjimka ).
Já bych definoval vlastní výjimku (obecnou TemplateError, případně z ní ještě odvozenou TemplateReadfileError) obsahující příslušné informace a do ní vložil původní výjimku - nikdy nevím, kdy framework použiju nebo jak moc se rozroste.
Když už jsme u toho, místo metody get_template bych udělal třídu Template buď obsahující metodu něco jako Load, nebo načítající template v konstruktoru - pro jistotu, nikdy nevím, co všechno budu chtít s templatem ještě dělat, aspoň by to bylo všechno v kupě.
Navíc možná by bylo dobré neotvírat přímo soubory z disku, ale vytvořit si třídu, která bude zajišťovat načítání dat podle nějakého identifikátoru (v tomhle nejjednodušším případě podle jména souboru), nikdy nevím, kdy budu chtít templaty třeba načítat z databáze... Záleží na tom, jak moc si představuješ, že se ten framework může rozrůst a na co všechno bys ho mohl chtít použít.
Tiskni Sdílej: