abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 01:44 | Nová verze

    Byla vydána nová verze 10.0 z Debianu vycházející linuxové distribuce DietPi pro (nejenom) jednodeskové počítače. Přehled novinek v poznámkách k vydání. Vypíchnout lze nové balíčky ownCloud Infinite Scale a Uptime-Kuma.

    Ladislav Hagara | Komentářů: 0
    včera 20:22 | Nová verze

    Enkodér a dekodér SVT-AV1 (Scalable Video Technology for AV1) byl vydán v nové major verzi 4.0.0.

    Ladislav Hagara | Komentářů: 0
    včera 18:44 | Nová verze

    Byla vydána nová verze 3.0.8 svobodné aplikace pro úpravu a vytváření rastrové grafiky GIMP (GNU Image Manipulation Program). Přehled novinek v oznámení o vydání a v souboru NEWS na GitLabu. Nový GIMP je již k dispozici také na Flathubu.

    Ladislav Hagara | Komentářů: 0
    24.1. 11:55 | Humor

    Microsoft poskytl FBI uživatelské šifrovací klíče svého nástroje BitLocker, nutné pro odemčení dat uložených na discích třech počítačů zabavených v rámci federálního vyšetřování. Tento krok je prvním známým případem, kdy Microsoft poskytl klíče BitLockeru orgánům činným v trestním řízení. BitLocker je nástroj pro šifrování celého disku, který je ve Windows defaultně zapnutý. Tato technologie by správně měla bránit komukoli kromě

    … více »
    NUKE GAZA! 🎆 | Komentářů: 33
    24.1. 01:44 | Komunita

    Spotify prostřednictvím svého FOSS fondu rozdělilo 70 000 eur mezi tři open source projekty: FFmpeg obdržel 30 000 eur, Mock Service Worker (MSW) obdržel 15 000 eur a Xiph.Org Foundation obdržela 25 000 eur.

    Ladislav Hagara | Komentářů: 4
    23.1. 18:11 | Zajímavý software

    Nazdar! je open source počítačová hra běžící také na Linuxu. Zdrojové kódy jsou k dispozici na GitHubu. Autorem je Michal Škoula.

    Ladislav Hagara | Komentářů: 3
    23.1. 16:55 | Nová verze

    Po více než třech letech od vydání verze 1.4.0 byla vydána nová verze 1.5.0 správce balíčků GNU Guix a na něm postavené stejnojmenné distribuci GNU Guix. S init systémem a správcem služeb GNU Shepherd. S experimentální podporou jádra GNU Hurd. Na vývoji se podílelo 744 vývojářů. Přibylo 12 525 nových balíčků. Jejich aktuální počet je 30 011. Aktualizována byla také dokumentace.

    Ladislav Hagara | Komentářů: 9
    23.1. 15:44 | Zajímavý software

    Na adrese gravit.huan.cz se objevila prezentace minimalistického redakčního systému GravIT. CMS je napsaný ve FastAPI a charakterizuje se především rychlým načítáním a jednoduchým ukládáním obsahu do textových souborů se syntaxí Markdown a YAML místo klasické databáze. GravIT cílí na uživatele, kteří preferují CMS s nízkými nároky, snadným verzováním (např. přes Git) a možností jednoduchého rozšiřování pomocí modulů. Redakční

    … více »
    2012 | Komentářů: 0
    23.1. 12:55 | Zajímavý software

    Tým Qwen (Alibaba Cloud) uvolnil jako open-source své modely Qwen3‑TTS pro převádění textu na řeč. Sada obsahuje modely VoiceDesign (tvorba hlasu dle popisu), CustomVoice (stylizace) a Base (klonování hlasu). Modely podporují syntézu deseti různých jazyků (čeština a slovenština chybí). Stránka projektu na GitHubu, natrénované modely jsou dostupné na Hugging Face. Distribuováno pod licencí Apache‑2.0.

    NUKE GAZA! 🎆 | Komentářů: 0
    23.1. 01:11 | Nová verze

    Svobodný citační manažer Zotero (Wikipedie, GitHub) byl vydán v nové major verzi 8. Přehled novinek v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (18%)
     (5%)
     (0%)
     (10%)
     (22%)
     (3%)
     (5%)
     (2%)
     (11%)
     (34%)
    Celkem 614 hlasů
     Komentářů: 17, poslední 22.1. 15:24
    Rozcestník

    BASH - IFS je mocná zbraň

    11.2.2005 12:15 | Přečteno: 10113× | BASH | poslední úprava: 11.2.2005 13:29

    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.dat
    ale 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++; done
    protož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.

           

    Hodnocení: 100 %

            špatnédobré        

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    Komentáře

    Diskuse byla administrátory uzamčena

    11.2.2005 13:10 unchallenger | skóre: 69 | blog: unchallenger
    Rozbalit Rozbalit vše $'\n'
    s/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.
    11.2.2005 13:40 Hynek (Pichi) Vychodil | skóre: 43 | blog: Pichi | Brno
    Rozbalit Rozbalit vše Re: $'\n'
    Dík moc za bugreport. V téhle podobě je to pro mě ideální, protože to edituju ve gvimu přes mozex ;-) To by mě zajímalo jestli by to bylo tak jednoduché v "normálním" editoru viz.Proč nemám rád VIM. Asi těžko to bude jednodušší než stisknout dvě klávesy :% kliknout prostředním tlačítkem a entr :-D

    To s tím $'\n' jsem zase neznal já. Když ten bash(1) je tak rozsáhlý a já myslel, že v sekci QUOTING se nedočtu nic zajímavého ;-)
    XML je zbytečný, pomalý, nešikovný balast, znovu vynalézané kolo a ještě ke všemu šišaté, těžké a kýčovitě pomalované.
    11.2.2005 14:11 Martin Čížek | skóre: 20 | Praha
    Rozbalit Rozbalit vše Re: $'\n'
    Sakra, asi bych měl otevřené záložky hned zpracovávat, abych nechodil s křížkem po funuse :-).
    Kdyby dva z nás byli dvěma z nich, všichni z nás by mohli být všemi z nich.
    11.2.2005 14:09 Martin Čížek | skóre: 20 | Praha
    Rozbalit Rozbalit vše Jak pěkně nacpat do IFS (či jinam) divotvorné znaky
    Tak třeba mezera, tabulátor, nový řádek:
    IFS=$' \t\n'
    Kdyby dva z nás byli dvěma z nich, všichni z nás by mohli být všemi z nich.
    11.2.2005 14:37 Hynek (Pichi) Vychodil | skóre: 43 | blog: Pichi | Brno
    Rozbalit Rozbalit vše Re: Jak pěkně nacpat do IFS (či jinam) divotvorné znaky
    Kdybych si přečetl QUOTING tak bych to třeba věděl taky :-) Je fakt, že takhle to vypadá jako bych se pokoušel o most obfuscated verzi jednoduchého IFS=$'\n'

    P.S.: Furt se něco učím.
    XML je zbytečný, pomalý, nešikovný balast, znovu vynalézané kolo a ještě ke všemu šišaté, těžké a kýčovitě pomalované.
    11.2.2005 15:41 Martin Čížek | skóre: 20 | Praha
    Rozbalit Rozbalit vše Re: Jak pěkně nacpat do IFS (či jinam) divotvorné znaky
    Já jsem si tam toho také dlouho nevšiml. Na dolar – uvozovka jsem poprvé narazil ve výstupu set, resp. set | grep IFS :-).
    Kdyby dva z nás byli dvěma z nich, všichni z nás by mohli být všemi z nich.
    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.