abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    25.5. 19:00 | Zajímavý projekt

    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.

    Ladislav Hagara | Komentářů: 11
    24.5. 22:22 | Upozornění Ladislav Hagara | Komentářů: 9
    24.5. 17:44 | Nová verze

    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).

    Fluttershy, yay! | Komentářů: 0
    24.5. 14:33 | Zajímavý software

    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.

    Ladislav Hagara | Komentářů: 1
    24.5. 13:33 | Nová verze

    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.

    Ladislav Hagara | Komentářů: 3
    23.5. 23:22 | Zajímavý software

    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.

    Ladislav Hagara | Komentářů: 0
    23.5. 16:55 | Nová verze

    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.

    Ladislav Hagara | Komentářů: 13
    23.5. 12:55 | Nová verze

    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.

    Ladislav Hagara | Komentářů: 0
    22.5. 23:44 | Pozvánky

    V neděli 26. května lze navštívit Maker Faire Rychnov nad Kněžnou, festival plný workshopů, interaktivních činností a především nadšených a zvídavých lidí.

    Ladislav Hagara | Komentářů: 0
    22.5. 16:33 | Nová verze

    Byla vydána nová stabilní verze 3.20.0, tj. první z nové řady 3.20, minimalistické linuxové distribuce zaměřené na bezpečnost Alpine Linux (Wikipedie) postavené na standardní knihovně jazyka C musl libc a BusyBoxu. Z novinek lze vypíchnou počáteční podporu 64bitové architektury RISC-V.

    Ladislav Hagara | Komentářů: 0
    Podle hypotézy Mrtvý Internet mj. tvoří většinu online interakcí boti.
     (88%)
     (3%)
     (5%)
     (4%)
    Celkem 804 hlasů
     Komentářů: 16, poslední 14.5. 11:05
    Rozcestník

    Dotaz: shell - oprava kódu

    22.10.2012 19:50 rBAR
    shell - oprava kódu
    Přečteno: 229×
    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.