Finálový zápas mistrovství světa v ledním hokeji přinesl nový rekord NIX.CZ (𝕏): "Dosavadní absolutní maximum našeho propojovacího uzlu bylo překonáno v čase 21:10, kdy jsme při přenosu dat dosáhli 3,14 Tbps. Je třeba také doplnit, že po deváté hodině večerní byly na maximu i ostatní datové přenosy nesouvisející s hokejovým šampionátem".
Přihlaste svou přednášku na další ročník konference LinuxDays, který proběhne 12. a 13. října na FIT ČVUT v pražských Dejvicích. CfP poběží do konce prázdnin, pak proběhne veřejné hlasování a výběr přednášek.
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.
Tak jsem zase potřeboval něco naprogramovat. Člověk by si řekl, když nevím jak na to v bashi, použij něco silnějšího, třeba perl. Ale to bych nebyl já, kdybych to aspoň nezkusil. Takže máme nějaký textový soubor s daty z měření a v něm za komentářem jsou popisky jednotlivých sloupečků. Kdyby to byla jen jedna série s jedněmi popisky, tak je to naprosto jednoduché, ale těch sérií je víc a jak na potvoru každá má jiné popisky. No a já z toho chci vytvořit příkaz pro gnuplot s tím, že si uživatel může vybrat kterou sérii a který sloupeček chce zobrazit. To vyžaduje mít možnost načíst jednotlivé popisky do proměných a pak se přes indexy k nim dostat při zpracování parametrů na příkazovém řádku. Pro ilustraci máme soubor mereni.dat:
# blabla komentar # title: x,y,z # title: x,s1 # title: x,s2 # prvni serie 1, 2, 3 2, 3, 4 #druha serie 1, 3 1, 4 #treti serie 1, 2 1, 1
Načtení celého souboru po řádcích by bylo celkem jednoduché
j=0 while read i; do radky[j]="$i"; let j++; done <mereni.datale krajně pomalé a zbytečné a další zpracvání v bashi ještě pomalejší a nepohodlnější. Při pokusu to načíst už odfiltrované narazíme pochopitelně na problém
j=0 sed '/^# *title:/!d;s/^# *title: *//' mereni.dat |\ while read i; do radky[j]="$i"; let j++; doneprotože cyklus while proběhne jako subproces a změna env (proměná radky) zůstane v subprocesu a už ji nikdy neuvidíme. To je ale pěkně hloupé. Když jsem nad tím přemýšlel, tak už jsem to chtěl zabalit, ale pak přišlo na scénu IFS. (Teda abych pravdu řekl, tak je ještě možnost si to uschovat do tmp souboru, ale nebuďme malí a měkcí.)
IFS určuje oddělovač: The Internal Field Separator that is used for word splitting after expansion and to split lines into words with the read builtin command. The default value is ``<space><tab><newline>''. Ve spojení s bashovými poli která zpracovávají
a=("řetězec")právě pomocí word spliting je myslím jasné, jak na to. Posledním zádrhelem je, jak nacpat do IFS právě jen a pouze konec řádku (mimochodem C-V C-M nebo Enter je \r tedy návrat vozíku a ne přechod na další řádek \n jak bych čekal), takže IFS="^M" vložené touto kombinací nefunguje, což mě málem přivedlo k myšlence, že je to rozbité. Není. Nejjednodušší je
IFS=" "Což při přepisu může být trošku matoucí takže uvažuji o "čitelnější" variantě
IFS="$(echo -e \"\\n\")"nebo
IFS="$(printf -e \"\\n\")"Brr, ale při přepisu někým jiným by v tom mohlo být míň chyb. Takže výsledkem může být něco takového
# natáhneme popisy titulků IFS="$(echo -e \"\\n\")" titles=($(sed '/^# *title:/!d;s/^# *title: *//' mereni.dat)) # na jdenom řádku je to proto, abych nemusel obnovovat IFS='' # k jednotlivým titulkům se pak dá snadno dostat pomocí IFS=',' title=(${titles[$serie]}) def=" t '${title[$column]}'"kde proměné serie a column získám obligátní cyklem zpracovávajícím paramery příkazového řádku.
Dobrou noc milé děti.
Tiskni Sdílej:
Diskuse byla administrátory uzamčena
11.2.2005 13:10s/nebuďme malý/nebuďme malí/ s/bashovými poly/bashovými poli/ s/rozbyté/rozbité/ s/Nejjednodužší/Nejjednodušší/A teď k věci. Zdaleka nejjednodušší způsob, jak dostat do IFS jen \n, je
IFS=$'\n':-) Ale jinak pěkné, s tou rourou by mi asi docela trvalo, než by mi to došlo.
IFS=$' \t\n'
set
, resp. set | grep IFS
.