Spolek OpenAlt zve příznivce otevřených řešení a přístupu na 209. brněnský sraz, který proběhne tento pátek 16. května od 18:00 ve studentském klubu U Kachničky na Fakultě informačních technologií Vysokého učení technického na adrese Božetěchova 2/1. Jelikož se Brno stalo jedním z hlavních míst, kde se vyvíjí open source knihovna OpenSSL, tentokrát se OpenAlt komunita potká s komunitou OpenSSL. V rámci srazu Anton Arapov z OpenSSL
… více »GNOME Foundation má nového výkonného ředitele. Po deseti měsících skončil dočasný výkonný ředitel Richard Littauer. Vedení nadace převzal Steven Deobald.
Byl publikován přehled vývoje renderovacího jádra webového prohlížeče Servo (Wikipedie) za uplynulé dva měsíce. Servo zvládne už i Gmail. Zakázány jsou příspěvky generované pomocí AI.
Raspberry Pi Connect, tj. oficiální služba Raspberry Pi pro vzdálený přístup k jednodeskovým počítačům Raspberry Pi z webového prohlížeče, byla vydána v nové verzi 2.5. Nejedná se už o beta verzi.
Google zveřejnil seznam 1272 projektů (vývojářů) od 185 organizací přijatých do letošního, již jednadvacátého, Google Summer of Code. Plánovaným vylepšením v grafických a multimediálních aplikacích se věnuje článek na Libre Arts.
Byla vydána (𝕏) dubnová aktualizace aneb nová verze 1.100 editoru zdrojových kódů Visual Studio Code (Wikipedie). Přehled novinek i s náhledy a videi v poznámkách k vydání. Ve verzi 1.100 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.
Open source platforma Home Assistant (Demo, GitHub, Wikipedie) pro monitorování a řízení inteligentní domácnosti byla vydána v nové verzi 2025.5.
OpenSearch (Wikipedie) byl vydán ve verzi 3.0. Podrobnosti v poznámkách k vydání. Jedná se o fork projektů Elasticsearch a Kibana.
PyXL je koncept procesora, ktorý dokáže priamo spúštat Python kód bez nutnosti prekladu ci Micropythonu. Podľa testov autora je pri 100 MHz približne 30x rýchlejší pri riadeni GPIO nez Micropython na Pyboard taktovanej na 168 MHz.
Grafana (Wikipedie), tj. open source nástroj pro vizualizaci různých metrik a s ní související dotazování, upozorňování a lepší porozumění, byla vydána ve verzi 12.0. Přehled novinek v aktualizované dokumentaci.
Zdravim nespavcov :) Uz dlhsi cas sa mordujem so spracovanim vstupnych dat v tvare:
#attr2:attr3:attr6:attr5 value2r1:value3r1:value6r1:value5r1 #attr1:attr5:attr3:attr2:attr6 value1r2:value5r2:value3r2:value2r2:value6r2 value1r3:value5r3:value3r3:value2r3:value6r3 #attr8:attr2:attr3:attr4:attr5:attr7:attr1 #attr1:attr2:attr3:attr5 value1r4:value2r4:value3r4:value5r4
Pravidla pre tvar vstupneho suboru:
Mojim cielom je dostat ich do tvaru:
#attr1:attr2:attr3:attr4:attr5:attr6:attr7:attr8 :value2r1:value3r1::value5r1:value6r1 value1r2:value2r2:value3r2::value5r2:value6r2 value1r3:value2r3:value3r3::value5r3:value6r3 value1r4:value2r4:value3r4::value5r4
pripadne:
#attr1:attr2:attr3:attr4:attr5:attr6:attr7:attr8 :value2-1:value3-1::value5-1:value6-1:: value1-2:value2-2:value3-2::value5-2:value6-2:: value1-3:value2-3:value3-3::value5-3:value6-3:: value1-4:value2-4:value3-4::value5-4:::
cize, vertikalne ich zarovnat a zoradit podla attrX
, ktore budu vypisane v prvom riadku vystupneho suboru ako hlavicka. Cielom je predpriprava suboru na dalsie spracovanie tabulkovym kalkulatorom. Viacero dvojbodiek na konci riadka ako je ukazane vyssie nicomu neprekaza, ale ani nie je potrebnych. (vychadzam z toho ze ich povolenim by sa dal zjednodusit kod, a tabulkovy kalkulator ich aj tak odignoruje
Zatial som dospel k nasledovnemu:
awk ' BEGIN { OFS=FS=":"; record=0 } # spracovanie zaciatku bloku; nazvy premennych ukladam do attr[i] { if ($0 ~ /^#/) { columns=split(substr($0,2),attr); #print"\n"; for(i in attr) print "attr["i"] = "attr[i]; #debug1 next; } # spracovanie riadkov s hodnotami; hodnoty ukladam do r[record, attr[i]] record++; numvalues=split($0,value); for(i=1;i<=numvalues;i++) { r[record SUBSEP attr[i]]= value[i]; print "r ["record", "attr[i]"] = "r[record SUBSEP attr[i]]; #debug2 } } END{ print "-----" #debug3 for (combined in r) { #print combined; #debug4 num=split(combined, separate, SUBSEP); #print separate[1], separate[2], r[separate[1] SUBSEP separate[2]]; #debug5 # a co dal? }
Vystupom z debug2
je
r [1, attr2] = value2r1 r [1, attr3] = value3r1 r [1, attr6] = value6r1 r [1, attr5] = value5r1 r [2, attr1] = value1r2 r [2, attr5] = value5r2 r [2, attr3] = value3r2 r [2, attr2] = value2r2 r [2, attr6] = value6r2 r [3, attr1] = value1r3 r [3, attr5] = value5r3 r [3, attr3] = value3r3 r [3, attr2] = value2r3 r [3, attr6] = value6r3 r [4, attr1] = value1r4 r [4, attr2] = value2r4 r [4, attr3] = value3r4 r [4, attr5] = value5r4, takze verim, ze data mam rozparsovane a ulozene v asociativnom poli v poriadku.
Problemom pre mna je, ako z tohoto vyskladat vysledny vypis. Potrebujem nejako rozumne toto pole vyiterovat, no napada ma len klasicka konstrukcia: dva zanorene fory, ktora mi tu ale fungovat nebude, kedze nemam dva pouzitelne indexy.
Nejake napady? :)
Řešení dotazu:
import sys attrs = set() data = [] for line in sys.stdin: line = line.strip() if not line: continue if line[0] == '#': currentattrs = line[1:].split(':') attrs.update(currentattrs) else: data.append(dict(zip(currentattrs, line.split(':')))) keys = list(sorted(attrs)) print '#' + ':'.join(keys) for row in data: print ':'.join(row.get(k, '') for k in keys)
BEGIN { OFS=FS=":"; record=0 } # spracovanie zaciatku bloku; nazvy premennych ukladam do attr[i] { if ($0 ~ /^#/) { columns = split(substr($0, 2), attr); for(c in attr) { # ulozim si vsechny attributy all[attr[c]] = attr[c]; } next; } # spracovanie riadkov s hodnotami; hodnoty ukladam do r[record, attr[i]] record++; numvalues = split($0, value); for(i = 1; i <= numvalues; i++) { r[record, attr[i]] = value[i]; } } END{ nc = asort(all, sort); # vypis hlavicky ORS = ""; print("#"); ORS = ":"; for (c = 1; c < nc; c++) { print(sort[c]); } ORS = "\n"; print(sort[c]); # vypis obsahu for (l = 1; l <= record; l++) { ORS = ":"; for (c = 1; c < nc; c++) { print(r[l, sort[c]]); } ORS = "\n"; print(r[l, sort[c]]); } }Vysledek:
$ awk -f s.awk < in.txt #attr1:attr2:attr3:attr4:attr5:attr6:attr7:attr8 :value2r1:value3r1::value5r1:value6r1:: value1r2:value2r2:value3r2::value5r2:value6r2:: value1r3:value2r3:value3r3::value5r3:value6r3:: value1r4:value2r4:value3r4::value5r4:::
Tiskni
Sdílej: