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 04:00 | Zajímavý software

    Nourish (GitHub) je nový správce oken pro Linux. Tradiční plochy nahrazuje nekonečným plátnem a posouváním a přibližováním. Využívá vlastní kompozitor pro Wayland s názvem y5. Videoukázka.

    Ladislav Hagara | Komentářů: 0
    včera 15:33 | Komunita

    Po 20 letech a 17 otevřených (open source) krátkých filmech Blender Studio oznámilo plán na svůj první celovečerní film. Cílem samozřejmě není jenom nový otevřený film, ale především vývoj a vylepšení otevřených nástrojů pro spolupráci napříč celým procesem a vytvoření otevřené příručky (playbook) pro filmovou produkci ve velkém měřítku s informacemi, které jsou obvykle dostupné pouze uvnitř komerčních studií, a pomoci tak nezávislým tvůrcům překonat technické a organizační bariéry.

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

    Byla vydána nová verze 26.6.25 svobodného multiplatformního video editoru Shotcut (Wikipedie) postaveného nad multimediálním frameworkem MLT. Shotcut je vedle zdrojových kódů k dispozici také ve formátech AppImage, Flatpak a Snap.

    Ladislav Hagara | Komentářů: 0
    26.6. 14:44 | IT novinky

    Apple bez varování odstranil ze svého obchodu sociální síť VKontaktě i další aplikace skupiny VK, jako je VK Music nebo VK Video [Novinky.cz].

    Ladislav Hagara | Komentářů: 13
    26.6. 14:22 | IT novinky

    V dubnu loňského roku představený poštovní klient Notion Mail bude 22. září ukončen.

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

    Konference OpenAlt 2026 hledá přednášející. Proběhne o víkendu 7. a 8. listopadu na půdě Fakulty informačních technologií VUT v Brně. Témata konference jsou: Otevřený a svobodný software, IoT a Hnutí tvůrců, Vzdělávání, Bezpečnost a soukromí, Otevřená společnost, komunity a data, OpenMobility a další.

    Ladislav Hagara | Komentářů: 0
    26.6. 04:22 | IT novinky

    Společnosti OpenAI a Broadcom oznámily čip optimalizovaný pro AI pojmenovaný Jalapeño.

    Ladislav Hagara | Komentářů: 0
    25.6. 20:22 | Nová verze

    Deno (Wikipedie), běhové prostředí (runtime) pro JavaScript, TypeScript a WebAssembly, bylo vydáno v nové verzi 2.9. Hlavní novinkou je deno desktop pro převod Deno projektu na desktopovou aplikaci. Jedná se o alternativu k frameworkům Electron nebo Tauri.

    Ladislav Hagara | Komentářů: 2
    25.6. 15:44 | IT novinky

    Od zítra jsou Datové schránky oficiálně na nové adrese datovka.gov.cz. Adresa mojedatovaschranka.cz zůstává funkční do 27. srpna 2026, následně budou uživatelé automaticky přesměrováni na datovka.gov.cz.

    Ladislav Hagara | Komentářů: 3
    25.6. 13:44 | Nová verze

    Dolphin (Wikipedie), tj. open source multiplatformní emulátor herních konzolí GameCube a Wii od Nintenda, byl vydán ve verzi 2606. S podporou Game Boy Playeru.

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


    Dotaz: Načtení souboru do pole

    14.5.2007 10:43 pok | skóre: 11
    Načtení souboru do pole
    Přečteno: 1429×
    Zdravím.

    Chci nějak elegantně načíst obsah souboru do pole, řádek po řádku. Původně jsem si to představoval takto:

    a=( `cat vstup.txt` )

    ale protože na jednotlivých řádcích vstupního souboru je víc slov oddělených mezerou, nedaří se mi. Doufal jsem že toto pomůže:

    a=( $( echo $( cat vstup.txt | sed -e "s/\(.*\)/\"\1\"/g" ) ) )

    Ale i takto dostávám jednotlivé prvky v poli jako jednotlivá slova v souboru. Pravděpodobně mi uniká nějaké nutné escapování. Napadá někoho něco?

    Například:

    Pro soubor:
    a b
    c d e
    f g h
    dostávám:
    echo ${a[2]}
    "c
    BTW: Toto funguje jak chci:
    i=0
    while read line; do
      field[$i]="$line"
      i=`expr $i + 1`
    done < vstup.txt

    Odpovědi

    14.5.2007 12:11 Vojtěch Horký | skóre: 39 | blog: Vojtův zápisník | Praha
    Rozbalit Rozbalit vše Re: Načtení souboru do pole

    Zdravím, ten první příkaz je OK. Stačí předtím nastavit proměnnou IFS pouze na znak nového řádku (protože bash řeže řetězec na tokeny podle znaků v ní nalezených).

    Čili:

    IFS=$'\n';
    a=(`cat vstup.txt`);

    S pozdravem
    - Vojta

    I am always ready to learn although I do not always like to be taught. (W. Churchill)
    14.5.2007 12:27 pok | skóre: 11
    Rozbalit Rozbalit vše Re: Načtení souboru do pole
    Ha, díky!
    14.5.2007 18:16 Vojtěch Horký | skóre: 39 | blog: Vojtův zápisník | Praha
    Rozbalit Rozbalit vše Re: Načtení souboru do pole

    Ještě jsem si vzpomněl na něco.

    1. Pole má určitě omezenou velikost, takže na velký soubor to asi nebude fungovat (jako maximum bych viděl pár desítek řádků).
    2. Potom by to chtělo obnovit tu IFS na původní hodnotu (takže si na začátku její nastavení zapamatovat do jiné proměnné)

    - Vojta

    I am always ready to learn although I do not always like to be taught. (W. Churchill)
    14.5.2007 12:11 maleprase | skóre: 28
    Rozbalit Rozbalit vše Re: Načtení souboru do pole
    a v cem ze teda nevyhovuje ten priklad na konci ktery funguje jak chces?
    14.5.2007 12:25 pok | skóre: 11
    Rozbalit Rozbalit vše Re: Načtení souboru do pole
    Nešlo mi ani tak o funkci jako spíš o to, proč to nejde tak jak jsem to zkoušel prvně.
    15.5.2007 11:18 mlz | skóre: 12 | blog: Obcas
    Rozbalit Rozbalit vše Re: Načtení souboru do pole
    Zdravím, přijde mi řešit to bashem jako plýtvání zdroji a prostředky a beru to tedy jako cvičení. Ale nevím, pro jaké účely, tak asi prudím zbytečně.

    Ale existuje sed, awk, perl .. a neřeknu Monty
    15.5.2007 13:04 Jan Martinek | skóre: 43 | blog: johny | Brno
    Rozbalit Rozbalit vše Re: Načtení souboru do pole
    K tomuto komentáři se rád připojím. Pythonní
    a = file('vstup.txt').readlines()
    
    Je asi 30x rychlejší než ten příklad v bashi. Soubor s milionem řádků je načtený za 0.7 sekund, zatímco bash se s tím patle 22 sekund. A hlavně - na tak primitivní věc by se v pythonu nikdo neptal, zatímco v bashi je to věda.
    Je mi jasné, že autor dotazu ví co dělá, takže toto píšu spíš pro náhodného kolemjdoucího čtenáře.

    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.