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

    Bylo oznámeno vydání nové verze 8.1 "Hoare" kolekce svobodného softwaru umožňujícího nahrávání, konverzi a streamovaní digitálního zvuku a obrazu FFmpeg (Wikipedie). Doprovodný příspěvek na blogu Khronosu rozebírá kódování a dekódování videa pomocí Vulkan Compute Shaders v FFmpeg.

    Ladislav Hagara | Komentářů: 0
    dnes 04:33 | Zajímavý projekt

    Byl představen open-source a open-hardware prototyp nízkonákladového raketometu kategorie MANPADS, který byl sestaven z běžně dostupné elektroniky a komponent vytištěných na 3D tiskárně. Raketa využívá skládací stabilizační křidélka a canardovou stabilizaci aktivně řízenou palubním letovým počítačem ESP32, vybaveným inerciální měřicí jednotkou MPU6050 (gyroskop a akcelerometr). Přenosné odpalovací zařízení obsahuje GPS,

    … více »
    NUKE GAZA! 🎆 | Komentářů: 0
    včera 14:22 | IT novinky

    Vědci z univerzity La Sapienza v Římě vyvinuli systém, který dokáže identifikovat jednotlivce pouze na základě toho, jak narušují signály Wi-Fi. Autoři tuto novou technologii nazvali WhoFi. Na rozdíl od tradičních biometrických systémů, jako jsou skenery otisků prstů a rozpoznávání obličeje, nevyžaduje tato metoda přímý fyzický kontakt ani vizuální vstupy. WhoFi může také sledovat jednotlivce na větší ploše než kamera s pevnou polohou; stačí, je-li k dispozici Wi-Fi síť.

    Ladislav Hagara | Komentářů: 8
    včera 04:22 | Nová verze

    SuperTux (Wikipedie), tj. klasická 2D plošinovka inspirovaná sérií Super Mario, byl vydán v nové verzi 0.7.0. Videoukázka na YouTube. Hrát lze i ve webovém prohlížeči.

    Ladislav Hagara | Komentářů: 7
    včera 03:11 | Zajímavý projekt

    Ageless Linux je linuxová distribuce vytvořená jako politický protest proti kalifornskému zákonu o věkovém ověřování uživatelů na úrovni OS (AB 1043). Kromě běžného instalačního obrazu je k dispozici i konverzní skript, který kompatibilní systém označí za Ageless Linux a levné jednodeskové počítače v ceně 12$ s předinstalovaným Ageless Linuxem, které se chystají autoři projektu dávat dětem. Ageless Linux je registrován jako operační

    … více »
    NUKE GAZA! 🎆 | Komentářů: 8
    15.3. 15:33 | Humor

    PimpMyGRC upravuje vzhled toolkitu GNU Radio a přidává alternativní barevná témata. Primárním cílem autora bylo pouze vytvořit tmavé prostředí vhodné pro noční práci, nicméně k dispozici je nakonec celá škála barevných schémat včetně možností různých animací a vizuálních efektů (plameny, matrix, bubliny...), které nepochybně posunou uživatelský zážitek na zcela jinou úroveň. Témata jsou skripty v jazyce Python, které nahrazují

    … více »
    NUKE GAZA! 🎆 | Komentářů: 3
    15.3. 14:33 | Nová verze Ladislav Hagara | Komentářů: 1
    15.3. 12:33 | Zajímavý projekt

    FRANK OS je open-source operační systém pro mikrokontrolér RP2350 (s FRANK M2 board) postavený na FreeRTOS, který přetváří tento levný čip na plně funkční počítač s desktopovým uživatelským rozhraním ve stylu Windows 95 se správcem oken, terminálem, prohlížečem souborů a knihovnou aplikací, ovládaný PS/2 myší a klávesnicí, s DVI video výstupem. Otázkou zůstává, zda by 520 KB SRAM stačilo každému 😅.

    NUKE GAZA! 🎆 | Komentářů: 4
    14.3. 22:55 | IT novinky

    Administrativa amerického prezidenta Donalda Trumpa by měla dostat zhruba deset miliard dolarů (asi 214 miliard Kč) za zprostředkování dohody o převzetí kontroly nad aktivitami sociální sítě TikTok ve Spojených státech.

    Ladislav Hagara | Komentářů: 2
    14.3. 21:33 | Nová verze

    Projekt Debian aktualizoval obrazy stabilní větve „Trixie“ (13.4). Shrnuje opravy za poslední dva měsíce, 111 aktualizovaných balíčků a 67 bezpečnostních hlášení. Opravy se týkají mj. chyb v glibc nebo webovém serveru Apache.

    |🇵🇸 | Komentářů: 2
    Které desktopové prostředí na Linuxu používáte?
     (16%)
     (7%)
     (0%)
     (11%)
     (29%)
     (2%)
     (5%)
     (1%)
     (13%)
     (24%)
    Celkem 1095 hlasů
     Komentářů: 26, poslední 12.3. 08:56
    Rozcestník

    Dotaz: Rozddělit soubor pomocí sed/awk/grep

    17.1.2011 20:50 jeleniste | skóre: 13 | blog: Prokustovo lože
    Rozddělit soubor pomocí sed/awk/grep
    Přečteno: 532×
    Je to asi snadná věc, měl bych bejt schopnej to vylaborovat sám. Ale ani s awkem, ani se sedem sem za tim nedělal, no, za optání nic nedám.
    M8m soubor (kterej reprezentuje obsah databáze, jsou to vypsaný řádky tabulek). Formát je následující:
    &nazev_tabulky;prvni_polozka;druha_polozka;..;.....;.......;nta_plozka
    pricemz textovy polozky muzou obsahovat konec radky, pak ale nasledujici radek nezacina ampresandem a ten radek predtim konci paznakem "¤". No a ja potrebuju vytahat radky, ktery patreji k jedne tabulce. Delal sem to pomoc grep ^\&tbl; ale to prave zahodilo pokracovani zaznamu po \n. No vim, ye to je trivka, ale neumim ten sed temer pouzivat, awk vubec. Byl bych vdecnej za nejaky nakopnuti do zacatku (myslim to obrazne).
    No, byl bysem schopnej na to napsat jednoduchej mlejnek v pajtnu, ale rad bych to udelal tim sedem/awkem, ktery sou na tohle asi mysleny.
    Dikec Je.
    Nejsem blbý, jen se hloupě ptám

    Řešení dotazu:


    Odpovědi

    17.1.2011 21:32 Ondřej Kopka | skóre: 19 | blog: ondrejk
    Rozbalit Rozbalit vše Re: Rozddělit soubor pomocí sed/awk/grep
    Na tohle bude asi nejlepší awk, hledej v manuálu FS a RS.
    17.1.2011 21:41 Ondřej Kubečka | skóre: 29 | blog: datlovo | Ulm
    Rozbalit Rozbalit vše Re: Rozddělit soubor pomocí sed/awk/grep
    Doufám, že to není domácí úkol. Pokud ano, tak nečtěte dále. ;)

    Jinak stručně awk, bez kontroly čekohokoliv (mimochodem třeba výskytu ampersantu na začátku řádku, i když se nejedná o pokračování předchozího záznamu... což samozřejmě také lze ;), taky to neřeší předchozí existenci souborů a já nevím co, prostě jenom kousek v awk, co to rozseká), pokud správně chápu Váš vstup a to, co chcete, aby z toho vypadlo, třeba takto:
    /usr/bin/awk -F';' '
    /^&/ {
       filename=$1
       sub(/^&/,"",filename)
    }
    {
       print >> filename
    }
    ' /cesta/k/vasemu/souboru
    
    Prostě při každém průchodu, když řádek začne &, tak se položka do prvního středníku bez & uloží do proměnné filename. Každý řádek se přidá do souboru s aktuálním jménem filename.
    18.1.2011 09:18 jeleniste | skóre: 13 | blog: Prokustovo lože
    Rozbalit Rozbalit vše Re: Rozddělit soubor pomocí sed/awk/grep
    Hehe, domácí úkol to není (respektive je to domácí úkol, kterej jsem dal sám sobě). Já to potřebuju do jednoho kšeftu, dělal jsem tyhle věci v pajtnu a zjistil jsem, že je možný je dělat rychlejc a elegantnějc. Dospěl sem k tomuto
    grep ^\B 3212.vfk | sed 's/^\&[BD]\([A-Z]*\).*/grep ^\\\&[BD]\1\\\; 3212.vfk > ..\/parts\/\1_3212.vfk/' | bash
    Ale to ten soubor prochází hodněkrát a navíc neumim udělat, aby to vzalo celej záznam i pokud obsahuje konec řádky. např:
    &nejaka_tabulka;polozka;polozka;polozka¤
    na¤
    hodne¤
    radku;polozka;polozka
    z takovýho záznamu mě to veme jen ten první řádek. Řešení, který bych použil já by asi zahrnovalo \n¤ v regexp, protože regexp sem zvyklej používat, ale mam za to, že to musí jít udělat nějak jednodušejc a potřeboval bych nakopnout správným směrem. Nepotřebuju, aby za mě někdo dělal domácí úkoly...
    Je.
    btw: v čelákovicích 2* denně přesedam.
    Nejsem blbý, jen se hloupě ptám
    18.1.2011 10:25 chochi | skóre: 29 | Praha
    Rozbalit Rozbalit vše Re: Rozddělit soubor pomocí sed/awk/grep
    awk by to mel zvladnout celkem s prehledem. Napr.:
    
    $ cat s
    &jina_tabulka;polozka;polozka;polozka3;polozka;polozka¤
    polozka
    &nejaka_tabulka;polozka;polozka;polozka¤
    na¤
    hodne¤
    radku;polozka;polozka
    &nejaka_tabulka;polozka;polozka;polozka¤
    2;polozka;polozka
    &jina_tabulka;polozka;polozka;polozka3;polozka;polozka
    &nejaka_tabulka;polozka;polozka;polozka3;polozka;polozka
    $ rm -f nejaka_tabulka jina_tabulka 
    $ gawk 'BEGIN {RS = "[^¤]\n"; ORS = ""; FS = ";"} /^&/{file=$1; sub(/^&/,"",file); print $0 RT >> file}' < s
    $ cat nejaka_tabulka 
    &nejaka_tabulka;polozka;polozka;polozka¤
    na¤
    hodne¤
    radku;polozka;polozka
    &nejaka_tabulka;polozka;polozka;polozka¤
    2;polozka;polozka
    &nejaka_tabulka;polozka;polozka;polozka3;polozka;polozka
    $ cat jina_tabulka 
    &jina_tabulka;polozka;polozka;polozka3;polozka;polozka¤
    polozka
    &jina_tabulka;polozka;polozka;polozka3;polozka;polozka
    
    18.1.2011 11:10 jeleniste | skóre: 13 | blog: Prokustovo lože
    Rozbalit Rozbalit vše Re: Rozddělit soubor pomocí sed/awk/grep
    Díky, to je přesně vono. Když koukám co ten awk umí, si řikam, že sem s pythonem celkem chodil s kanónem na vrabce. Díky moc.
    Nejsem blbý, jen se hloupě ptám
    18.1.2011 11:15 jeleniste | skóre: 13 | blog: Prokustovo lože
    Rozbalit Rozbalit vše Re: Rozddělit soubor pomocí sed/awk/grep
    Ještě jeden dotaz. Je mi celkem jasný co to dělá, až na dvě věci, to ORS, jakej má v tutom skriptu smysl??
    Nejsem blbý, jen se hloupě ptám
    18.1.2011 11:18 jeleniste | skóre: 13 | blog: Prokustovo lože
    Rozbalit Rozbalit vše Re: Rozddělit soubor pomocí sed/awk/grep
    Když to zrušim, přidá mě to prázdný řádky. Aha. asi chápu.
    Nejsem blbý, jen se hloupě ptám
    18.1.2011 11:23 jeleniste | skóre: 13 | blog: Prokustovo lože
    Rozbalit Rozbalit vše Re: Rozddělit soubor pomocí sed/awk/grep
    Když zrušim to RT na konci, tak to blbne, co má dělat to RT??
    Nejsem blbý, jen se hloupě ptám
    18.1.2011 11:58 chochi | skóre: 29 | Praha
    Rozbalit Rozbalit vše Re: Rozddělit soubor pomocí sed/awk/grep
    Viz man awk :-).
    ORS je "Output Record Separator" - ten se zapisuje mezi jednotli zaznamy na vystupu.
    RS je "Input Record Separator" - zjednodusene je to regularni vyraz podle ktereho se vstup rozklada na jednotlive zaznamy.
    RT je "Record terminator" - do tehle promene se nastavi ten text co matchuje RS.

    Pri parsovani vstupu awk v $0 vraci jen zaznam, bez tech casti ktere je oddeluji (RS). Takhle, jelikoz se matchuji dva znaky, by je ten vystup neobsahovl (jejich hodnota je ulozena v RT).
    Kdyz vypustis to RT tak zaznami by neobsohovaly posledni znak a novy radek.
    Defaultni hodnota je RS = ORS = new line.
    18.1.2011 12:33 jeleniste | skóre: 13 | blog: Prokustovo lože
    Rozbalit Rozbalit vše Re: Rozddělit soubor pomocí sed/awk/grep
    Aha, musel jsem si to zkusit, takže to RT vlastně awk nevnímá jako součást záznamu, ale jako oddělovač, tudíž ORS = "" a RT dávám proto, že kdybych nedal ORS a RT, tak mi to místo posledního znaku a konce řádu ustříhne poslední dva znaky a přidá konec řádku. Jasný. Díky.
    Nejsem blbý, jen se hloupě ptám

    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.