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 20:55 | Komunita

    curl up 2026, tj. setkání vývojářů a uživatelů curlu, proběhne opět v Praze. O víkendu 23. a 24. května v Pracovně.

    Ladislav Hagara | Komentářů: 0
    dnes 15:55 | IT novinky

    Aplikace pro ověřování věku uživatelů on-line platforem je technicky hotová a brzy bude k dispozici pro občany EU, oznámila dnes předsedkyně Evropské komise Ursula von der Leyenová. Půjde podle ní o bezplatné a snadno použitelné řešení, které pomůže chránit děti před škodlivým a nelegálním obsahem. Aplikace bude podle ní fungovat na jakémkoli zařízení a bude zcela anonymní.

    Ladislav Hagara | Komentářů: 3
    dnes 04:33 | Komunita

    V prosinci 2012 byla z linuxového jádra odstraněna podpora procesorů 386. Včera započalo odstraňování podpory procesorů 486.

    Ladislav Hagara | Komentářů: 0
    dnes 01:33 | IT novinky

    IuRe (Iuridicum Remedium) vyhlásila Ceny Velkého bratra za rok 2025. Slídily roku jsou automobilka Volkswagen, Meta a česká Ministerstva vnitra a průmyslu a obchodu. Autorem Výroku Velkého bratra je dánský ministr spravedlnosti zpochybňující právo na šifrovanou komunikaci. Naopak Pozitivní cenu získali studenti Masarykovy univerzity za odpor proti nucení do používaní aplikace ISIC.

    |🇵🇸 | Komentářů: 3
    včera 21:11 | Nová verze

    Po osmi měsících vývoje byla vydána nová verze 0.16.0 programovacího jazyka Zig (Codeberg, Wikipedie). Přispělo 244 vývojářů. Přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    včera 18:22 | Bezpečnostní upozornění

    Nejnovější X.Org X server 21.1.22 a Xwayland 24.1.10 řeší 5 bezpečnostních chyb: CVE-2026-33999, CVE-2026-34000, CVE-2026-34001, CVE-2026-34002 a CVE-2026-34003.

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

    Po roce vývoje od vydání verze 1.28.0 byla vydána nová stabilní verze 1.30.0 webového serveru a reverzní proxy nginx (Wikipedie). Nová verze přináší řadu novinek. Podrobný přehled v souboru CHANGES-1.30.

    Ladislav Hagara | Komentářů: 0
    včera 17:33 | Nová verze

    Raspberry Pi OS, oficiální operační systém pro Raspberry Pi, byl vydán v nové verzi 2026-04-13. Přehled novinek poznámkách k vydání. Nově ve výchozím nastavení příkaz sudo vyžaduje heslo.

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

    Společnost Blackmagic Design oznámila vydání verze 21 svého proprietárního softwaru pro editování videí a korekci barev DaVinci Resolve běžícího také na Linuxu. Z novinek je nutno vypíchnout možnost editování fotografií. Základní verze DaVinci Resolve je k dispozici zdarma. Plnou verzi DaVinci Resolve Studio lze koupit za 295 dolarů.

    Ladislav Hagara | Komentářů: 20
    včera 05:00 | Nová verze

    Multipatformní renderovací jádro webového prohlížeče Servo je na crates.io. S vydáním verze 0.1.0 (LTS).

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (14%)
     (8%)
     (1%)
     (12%)
     (30%)
     (3%)
     (6%)
     (2%)
     (15%)
     (25%)
    Celkem 1330 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: 298×
    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.