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

    raylib (Wikipedie), tj. multiplatformní open-source knihovna pro vývoj grafických aplikací a her, byla vydána ve verzi 6.0.

    Ladislav Hagara | Komentářů: 0
    24.4. 18:33 | IT novinky

    Nové verze AI modelů. Společnost OpenAI představila GPT‑5.5. Společnost DeepSeek představila DeepSeek V4.

    Ladislav Hagara | Komentářů: 0
    24.4. 15:33 | Zajímavý článek

    Nová čísla časopisů od nakladatelství Raspberry Pi zdarma ke čtení: Raspberry Pi Official Magazine 164 (pdf) a Hello World 29 (pdf).

    Ladislav Hagara | Komentářů: 0
    24.4. 04:44 | Komunita

    Bylo oznámeno, že webový prohlížeč Opera GX zaměřený na hráče počítačových her je už také na Flathubu and Snapcraftu.

    Ladislav Hagara | Komentářů: 0
    23.4. 23:11 | IT novinky

    Akcionáři americké mediální společnosti Warner Bros. Discovery dnes schválili převzetí firmy konkurentem Paramount Skydance za zhruba 110 miliard dolarů (téměř 2,3 bilionu Kč). Firmy se na spojení dohodly v únoru. O část společnosti Warner Bros. Discovery dříve usilovala rovněž streamovací platforma Netflix, se svou nabídkou však neuspěla. Transakci ještě budou schvalovat regulační orgány, a to nejen ve Spojených státech, ale také

    … více »
    Ladislav Hagara | Komentářů: 0
    23.4. 22:33 | Nová verze

    Canonical vydal (email, blog, YouTube) Ubuntu 26.04 LTS Resolute Raccoon. Přehled novinek v poznámkách k vydání. Vydány byly také oficiální deriváty Edubuntu, Kubuntu, Lubuntu, Ubuntu Budgie, Ubuntu Cinnamon, Ubuntu Kylin, Ubuntu Studio, Ubuntu Unity a Xubuntu. Jedná se o 11. vydání s dlouhodobou podporou (LTS).

    Ladislav Hagara | Komentářů: 2
    23.4. 11:55 | Nová verze

    V programovacím jazyce Go naprogramovaná webová aplikace pro spolupráci na zdrojových kódech pomocí gitu Gitea (Wikipedie) byla vydána v nové verzi 1.26.0. Přehled novinek v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    23.4. 04:44 | Pozvánky

    Ve středu 29. dubna 2026 se v pražské kanceláři SUSE v Karlíně uskuteční 7. Mobile Linux Hackday, komunitní setkání zaměřené na Linux na mobilních zařízeních, kernelový vývoj i uživatelský prostor. Akce proběhne od 10:00 do večerních hodin. Hackday je určen všem zájemcům o praktickou práci s Linuxem na telefonech. Zaměří se na vývoj aplikací v userspace, například bankovní aplikace, zpracování obrazu z kamery nebo práci s NFC, i na úpravy

    … více »
    lkocman | Komentářů: 1
    22.4. 21:55 | Nová verze

    LilyPond (Wikipedie) , tj. multiplatformní svobodný software určený pro sazbu notových zápisů, byl vydán ve verzi 2.26.0. Přehled novinek v aktualizované dokumentaci.

    Ladislav Hagara | Komentářů: 0
    22.4. 20:33 | Nová verze

    Byla vydána nová verze 11.0.0 otevřeného emulátoru procesorů a virtualizačního nástroje QEMU (Wikipedie). Přispělo 237 vývojářů. Provedeno bylo více než 2 500 commitů. Přehled úprav a nových vlastností v seznamu změn.

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