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 04:33 | Nová verze

    Open source software pro úpravu digitálních fotografií LightZone (Wikipedie) byl vydán v nové verzi 5.0.0. LightZone je dnes k dispozici pod licencí BSD. Původně se jednalo o proprietární software vyvíjený společností Light Crafts. Ta v prosinci 2012 souhlasila s uvolněním zdrojových kódů jako open source [Wayback Machine].

    Ladislav Hagara | Komentářů: 0
    23.5. 17:22 | Nová verze

    Byla vydána verze 0.84 telnet a ssh klienta PuTTY (Wikipedie). Podrobnosti v přehledu nových vlastností a oprav chyb a Change Logu.

    Ladislav Hagara | Komentářů: 2
    22.5. 19:44 | IT novinky

    Microsoft představil Azure Linux 4.0 a Azure Container Linux. Na konferenci Open Source Summit North America 2026 organizované konsorciem Linux Foundation a sponzorované také Microsoftem. Azure Linux 4.0 vychází z Fedora Linuxu. Azure Container Linux je založen na projektu Flatcar. Azure Linux (GitHub, Wikipedie) byl původně znám jako CBL-Mariner.

    Ladislav Hagara | Komentářů: 0
    22.5. 12:22 | Zajímavý článek

    Nové číslo časopisu Raspberry Pi zdarma ke čtení: Raspberry Pi Official Magazine 165 (pdf).

    Ladislav Hagara | Komentářů: 0
    22.5. 10:55 | Nová verze

    Byla vydána verze 9.2 open source virtualizační platformy Proxmox VE (Proxmox Virtual Environment, Wikipedie) založené na Debianu. Přehled novinek v poznámkách k vydání a informačním videu.

    Ladislav Hagara | Komentářů: 5
    22.5. 09:33 | IT novinky

    Firefox 151 podporuje Web Serial API. Pro komunikaci s různými mikrokontroléry připojenými přes USB nebo sériové porty už není nutné spouštět Chrome nebo na Chromiu postavené webové prohlížeče.

    Ladislav Hagara | Komentářů: 9
    22.5. 04:44 | Nová verze

    Byla vydána nová stabilní verze 8.0 webového prohlížeče Vivaldi (Wikipedie). Postavena je na Chromiu 148. Přehled novinek i s náhledy v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    21.5. 21:33 | Bezpečnostní upozornění

    Ve FreeBSD byla nalezena a opravena zranitelnost FatGid aneb CVE-2026-45250. Jedná se o lokální eskalaci práv. Neprivilegovaný uživatel se může stát rootem.

    Ladislav Hagara | Komentářů: 0
    21.5. 14:33 | IT novinky

    Společnost Flipper Devices oznámila Flipper One. Zcela nový Flipper postavený od nuly. Jedná se o open-source linuxovou platformu založenou na čipu Rockchip RK3576. Hledají se dobrovolníci pro pomoc s dokončením vývoje (ovladače, testování, tvorba modulů).

    Ladislav Hagara | Komentářů: 2
    21.5. 14:00 | Nová verze

    Vývojáři Wine oznámili vydání verze 2.0 knihovny vkd3d pro překlad volání Direct3D na Vulkan. Přehled novinek na GitLabu.

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (12%)
     (8%)
     (2%)
     (14%)
     (31%)
     (4%)
     (6%)
     (3%)
     (16%)
     (26%)
    Celkem 1702 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník

    Dotaz: shell - oprava kódu

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