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í
×
    včera 15:00 | Zajímavý článek

    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.

    Ladislav Hagara | Komentářů: 2
    9.5. 17:22 | Nová verze

    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.

    Ladislav Hagara | Komentářů: 0
    9.5. 15:22 | Komunita

    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.

    Ladislav Hagara | Komentářů: 0
    8.5. 19:22 | Nová verze

    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.

    Ladislav Hagara | Komentářů: 0
    8.5. 18:00 | Nová verze

    Open source platforma Home Assistant (Demo, GitHub, Wikipedie) pro monitorování a řízení inteligentní domácnosti byla vydána v nové verzi 2025.5.

    Ladislav Hagara | Komentářů: 0
    8.5. 01:22 | Nová verze Ladislav Hagara | Komentářů: 0
    8.5. 00:55 | Zajímavý projekt

    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.

    vlk | Komentářů: 0
    7.5. 19:44 | Nová verze

    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.

    Ladislav Hagara | Komentářů: 0
    7.5. 17:33 | Nová verze

    Raspberry Pi OS, oficiální operační systém pro Raspberry Pi, byl vydán v nové verzi 2025-05-06. Přehled novinek v příspěvku na blogu Raspberry Pi a poznámkách k vydání. Pravděpodobně se jedná o poslední verzi postavenou na Debianu 12 Bookworm. Následující verze by již měla být postavena na Debianu 13 Trixie.

    Ladislav Hagara | Komentářů: 0
    7.5. 05:33 | Komunita

    Richard Stallman dnes v Liberci přednáší o svobodném softwaru a svobodě v digitální společnosti. Od 16:30 v aule budovy G na Technické univerzitě v Liberci. V anglickém jazyce s automaticky generovanými českými titulky. Vstup je zdarma i pro širokou veřejnost.

    Ladislav Hagara | Komentářů: 17
    Jaký filesystém primárně používáte?
     (57%)
     (1%)
     (8%)
     (22%)
     (4%)
     (2%)
     (3%)
     (1%)
     (1%)
     (3%)
    Celkem 579 hlasů
     Komentářů: 26, poslední 8.5. 09:58
    Rozcestník

    Dotaz: shell - oprava kódu

    22.10.2012 19:50 rBAR
    shell - oprava kódu
    Přečteno: 261×
    Zdravím, sažím se načíst jednotlivé řádky ze souboru do pole a následně je rozpůlit podle znaku IFS a uložit každou půlku do samostatné proměnné. Poradí někdo kde mám problém?
    IFS="+"
    
    PART=()
    i=0
    while read line
    do
      PART=("$line")
      PART_L_"$i"="${PART[0]}"
      PART_P_"$i"="${PART[1]}"
      (( i++ ))
    done</tmp/fce.txt
    
    v souboru instalace.txt je každý řádek v uvozovkách
    "funkce_jedna+FCE Jedna"
    "funkce_dve  +FCE Dvě  "
    "funkce_tri  +FCE Tři  "  
    Když vypíšu třeba $PART_L_3 tak se nic nevypíše.... Poraďte prosím. D.

    Odpovědi

    22.10.2012 20:16 l4m4
    Rozbalit Rozbalit vše Re: shell - oprava kódu
    Myslíš další problém kromě toho, že se snažíš zpracovávat komplexní data v shellu?

    Na první pohled je nesmysl toto:

    PART_L_"$i"=...

    Nejenže to neudělá, co čekáš, ale na tohle ti snad shell musí reagovat errorem, takže mě překvapuje, že si stěžuješ pouze na to, že je PART_L_3 prázdná (což tak jako tak být musí, když při číslování od nuly dostane poslední položka souboru číslo dva). Je-li nutné něco podobného dělat, musíš použít eval:

    eval PART_L_"$i"=...

    Ale možná by bylo lepší popsat, co má být celkový výsledek té operace, protože ji nejspíš lze provést bez bastlení v shellu.
    22.10.2012 20:56 camel1cz | skóre: 25
    Rozbalit Rozbalit vše Re: shell - oprava kódu
    To IFS ti ovlivní chování funkce read, ale té dáváš pouze jeden parametr a tak to shell nemá kam nacpat a celý rádek dá do proměnné line... řešení jsou 2:

    a) buď přidej fci read parametr -a (proměnnou line bude pak brát jako pole a nastaví ho podle IFS) a nebo

    b) dej fci read druhý parametr a pak ti rovnou dá vše před IFS do první proměnné a za IFS do druhé proměnné...

    Jinak ale souhlas s kolegou - zpracovávat taková data v shellu je řekněme nestandardní :-)

    22.10.2012 21:00 Delaunay | skóre: 17 | blog:
    Rozbalit Rozbalit vše Re: shell - oprava kódu
    awk
    22.10.2012 21:12 Kit
    Rozbalit Rozbalit vše Re: shell - oprava kódu
    To se všichni zbláznili, že chtějí v Bashi řešit práci s polem? Bash to umí, ale je to nepřehledné, líné a nepříliš bezpečné. Proč si na to nevezmeš jiný nástroj, který na takové záležitosti byl vytvořen, třeba AWK nebo Perl?
    23.10.2012 13:40 mike
    Rozbalit Rozbalit vše Re: shell - oprava kódu
    #!/bin/bash
    
    FNAME=tst_in
    OUT_FNAME_1=tst_out_1
    OUT_FNAME_2=tst_out_2
    
    OUT_FNAME=$OUT_FNAME_1
    for line in $(cat $FNAME)
    do
        if [ x$line = "x+" ]
        then
    	OUT_FNAME=$OUT_FNAME_2
        else
    	echo $line >> $OUT_FNAME
        fi
    done
    
    23.10.2012 14:24 mike
    Rozbalit Rozbalit vše Re: shell - oprava kódu
    nepochopeno zadani
    23.10.2012 13:56 Kit
    Rozbalit Rozbalit vše Re: shell - oprava kódu
    tr -d '"' <instalace.txt |
       while IFS="+" read a b; do
          echo "$a, $b"
       done
    
    23.10.2012 15:13 l4m4
    Rozbalit Rozbalit vše Re: shell - oprava kódu
    Akorát následující pořadavek bude, že potřebuje ty proměnné i po skončení roury...
    23.10.2012 15:20 Kit
    Rozbalit Rozbalit vše Re: shell - oprava kódu
    To je mi jasné, ale už se mi s takovou hloupostí nechtělo patlat. Chtěl jsem tím jen ukázat, že příkaz read může mít víc parametrů. Zadání je nesmyslné, tak proč to řešit do detailů?

    Založit nové vláknoNahoru

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

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.