Protože je už po aprílu, můžou strahováci opět zveřejnit program další Virtuální Bastlírny, aniž by připravená témata působila dojmem, že jde o žert. Vězte tedy, že již v úterý 7. dubna od 20:00 proběhne VB, kde se setkají bastlíři, technici, učitelé i nadšenci do techniky a kde i vy se můžete zapojit do družného hovoru, jako by všichni seděli u pomyslného piva. Co mají bastlíři tento měsíc na srdci? Pravděpodobně by nás musel zasáhnout meteorit
… více »Byla vydána verze 26.1 aneb čtvrtletní aktualizace open source počítačového planetária Stellarium (Wikipedie, GitHub). Vyzkoušet lze webovou verzi Stellaria na Stellarium Web.
VOID (Video Object and Interaction Deletion) je nový open-source VLM model pro editaci videa, který dokáže z videí odstraňovat objekty včetně všech jejich fyzikálních interakcí v rámci scény (pády, kolize, stíny...) pomocí quadmaskingu (čtyřhodnotová maska, která člení pixely scény do čtyř kategorií: objekt určený k odstranění, překrývající se oblasti, objektem ovlivněné oblasti a pozadí scény) a dvoufázového inpaintingu. Za projektem stojí výzkumníci ze společnosti Netflix.
Design (GitHub) je 2D CAD pro GNOME. Instalovat lze i z Flathubu. Běží také ve webovém prohlížeči.
Příspěvek na blogu herního enginu Godot představuje aplikaci Xogot přinášející Godot na iPad a iPhone. Instalovat lze z App Storu. Za Xogotem stojí Miguel de Icaza (GitHub) a společnost Xibbon.
Na čem pracují vývojáři webového prohlížeče Ladybird (GitHub)? Byl publikován přehled vývoje za březen (YouTube).
ESP-IDF (Espressif IoT Development Framework), tj. oficiální vývojový framework pro vývoj aplikací na mikrokontrolérech řady ESP32, byl vydán v nové verzi 6.0. Detaily na portálu pro vývojáře.
DeepMind (Alphabet) představila novou verzi svého multimodálního modelu, Gemma 4. Modely jsou volně k dispozici (Ollama, Hugging Face a další) ve velikostech 5-31 miliard parametrů, s kontextovým oknem 128k až 256k a v dense i MoE variantách. Modely zvládají text, obrázky a u menších verzí i audio. Modely jsou optimalizované pro běh na desktopových GPU i mobilních zařízeních, váhy všech těchto modelů jsou uvolněny pod licencí Apache 2.0. Návod na spuštění je už i na Unsloth.
Cursor (Wikipedie) od společnosti Anysphere byl vydán ve verzi 3. Jedná se o multiplatformní proprietární editor kódů s podporou AI (vibe coding).
Průkopnická firma FingerWorks kolem roku 2000 vyvinula vícedotykové trackpady s gesty a klávesnice jako TouchStream LP. V roce 2005 ji koupil Apple, výrobu těchto produktů ukončil a dotykové technologie využil při vývoji iPhone. Multiplatformní projekt Apple Magic TouchstreamLP nyní implementuje funkcionalitu TouchStream LP na současném Apple Magic Trackpad, resp. jejich dvojici. Diskuze k vydání probíhá na Redditu.
array=($(cat mujsoubor.txt)) <- ve skutecnosti je tam slozitejsi sed a awk, ktery z procesuje soubor a udela vystup viz nize
mujsoubor.txt radek;654645 jana;13221 andrea;55465 ...
ted bych potreboval jednotlive radky ulozit do promennych, zkousel jsem
while IFS=';' read jmeno cislo; do
echo $jmeno
echo $cislo
done < ${array[*]}
Ale bohuzel takto mi to nefunguje, poradite? Zkousim v bashi.
Diky
mujsoubor.txt radek;654645 jana;13221 andrea;55465Retezec 'mujsoubor.txt' se nachazi v souboru a je potreba jej vynechat? Soubor obsahuje jeden dlouhy retez nebo radky? Je treba spojit 'radek' a 654645, nebo 654645 a 'jana'? K cemu je pak retezec 'radek'? Nezname format vstupniho souboru, ani vystupniho, je mozne, ze cele reseni lze nafromatovat rovnou ze vstupniho souboru, bez zbytecnych cyklu. Konecne pokud se jedna o domaci ulohu, tak ta sem nepatri vubec.
mujsoubor.txt radek;654645 jana;13221 andrea;55465Muj cil je tento seznam projet a nacist si pokazde prvni promennou=radek a druhou=654654, atd, dokud jsou tam radky. Omlouvam se za zmateni
. mujsoubor.shTa tečka vpředu není překlep, ale příkaz.
cat mujsoubor.txt |
while IFS=';' read cislo jmeno; do
echo $jmeno
echo $cislo
done
ale stejně by to v AWK bylo rychlejší a pohodlnější:
cat mujsoubor.txt |
awk 'BEGIN {RS=";"} {print $2, $1}'
Ovšem cpát to do pole je nesmysl. Máš k tomu nějaký závažný důvod?
Tohle by měla být povinná četba, klidně místo Lojzy Jiráska. 
Ne, já budu napřed mudrovat, protože pipeline začínající na cat jednoho souboru je prostě špatný příklad, celkem bez ohledu na okolnosti. Povaluje se na webu v nesčetných obměnách a přijde mi zbytečné přidávat další. Jak si to tazatel upraví, aby mu to četlo pipe z jiného programu, to už je jeho věc.
Děkuji, ale dobře jsem rozuměl, co tím myslel. Výsledkem ovšem je, že se na webu povalují zase další dva špatné příklady použití cat (který má, pravda, představovat „něco jiného“). Ať tak nebo tak, ty příklady jsou prostě špatné. Když už ne kvůli procesu navíc, tak třeba kvůli subshellu. Pro ilustraci je nejlepší třeba tohle:
cat /etc/passwd | readarray -t pole_na_hovno readarray -t pole_s_daty < /etc/passwd
První pole bude prázdné (protože takhle pipe prostě funguje, forknutý shell nemůže ovlivnit proměnné v tom původním), zatímco to druhé bude definované v „hlavním“ shellu, jak by člověk čekal. Při čtení dat do pole je cat jednoho souboru a následný pipe v podstatě zdrojem chyb číslo jedna. Když nahradíme cat za něco jiného, nijak to nepomůže. Tentýž problém tam bude pořád. Snad jediný případ, kdy cat jednoho souboru dává smysl, je něco takového:
{ sed 's/\(^[^:]\+\):/another\1:/' /etc/passwd; cat /etc/passwd; } | další | zpracování
Tohle^^^ je samozřejmě ptákovina, ale umím si představit, že by to s drobnou obměnou mohlo dělat něco smysluplného. Možná je ale přehlednější tohle:
cat <(sed 's/\(^[^:]\+\):/another\1:/' /etc/passwd) /etc/passwd | další | zpracování
A to už není cat jednoho souboru, takže to je celkem OK. První možnost může být o něco efektivnější, protože výstup ze sedu nemusí přežvýkat cat. Pokud ovšem cat i shell používají v tomto případě splice(), je to nakonec jedno, co do efektivity.
První a nejsnazší možnost je tohle:
while read line; do
IFS=';' read jmeno cislo <<<"${line}"
echo "Jméno: ${jmeno}"
echo "Číslo: ${cislo}"
done < mujsoubor.txt
Pokud chceš experimentovat s polem a načíst si řádky napřed do pole, to je samozřejmě taky možné:
readarray -t lines < mujsoubor.txt
for line in "${lines[@]}"; do
IFS=';' read jmeno cislo <<<"${line}"
echo "Jméno: ${jmeno}"
echo "Číslo: ${cislo}"
done
Pro úplnost dodávám, že vstupní soubor vypadá takto…
radek;654645 jana;13221 andrea;55465
…a výstup z tohoto „parseru“ vypadá v obou případech takto:
Jméno: radek Číslo: 654645 Jméno: jana Číslo: 13221 Jméno: andrea Číslo: 55465
Všechny výše uvedené parametry jsou popsané v man bash; stačí si najít kapitolu zvanou Shell Builtin Commands, která je tam někde ke konci.
Jo a mimochodem, pole přináší jistý bonus navíc v podobě indexů, které můžeš použít třeba pro následující trik, chceš-li:
readarray -t lines < mujsoubor.txt
echo "Počet položek adresáře: ${#lines[@]}"
for index in "${!lines[@]}"; do
IFS=';' read jmeno cislo <<<"${lines[index]}"
echo "$((index + 1)). záznam: Jméno: ${jmeno} Číslo: ${cislo}"
done
Výstup z posledního skriptu bude pak následující:
Počet položek adresáře: 3 1. záznam: Jméno: radek Číslo: 654645 2. záznam: Jméno: jana Číslo: 13221 3. záznam: Jméno: andrea Číslo: 55465
Z výše uvedeného už snad nebude problém nějaký vhodný parsovací skript vymyslet. 
Aha! Příliš jsem se nechal unést iterací přes pole a parsováním řádků za každou cenu. On ale read sám od sebe umí všechno potřebné, takže ještě kratší (se stejným výstupem) bude tohle:
while IFS=';' read jmeno cislo; do
echo "Jméno: ${jmeno}"
echo "Číslo: ${cislo}"
done < mujsoubor.txt
Tiskni
Sdílej: