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 10:22 | Upozornění

    Ze systému Slavia pojišťovny uniklo přibližně 150 gigabajtů citlivých dat. Jedná se například o pojistné dokumenty, lékařské záznamy nebo přímou komunikaci s klienty. Za únik může chyba dodavatelské společnosti.

    Ladislav Hagara | Komentářů: 3
    dnes 10:11 | IT novinky

    Sněmovna propustila do dalšího kola projednávání vládní návrh zákona o digitální ekonomice, který má přinést bezpečnější on-line prostředí. Reaguje na evropské nařízení DSA o digitálních službách a upravuje třeba pravidla pro on-line tržiště nebo sociální sítě a má i víc chránit děti.

    Ladislav Hagara | Komentářů: 19
    dnes 09:33 | IT novinky

    Meta převezme sociální síť pro umělou inteligenci (AI) Moltbook. Tvůrci Moltbooku – Matt Schlicht a Ben Parr – se díky dohodě stanou součástí Meta Superintelligence Labs (MSL). Meta MSL založila s cílem sjednotit své aktivity na poli AI a vyvinout takovou umělou inteligenci, která překoná lidské schopnosti v mnoha oblastech. Fungovat by měla ne jako centralizovaný nástroj, ale jako osobní asistent pro každého uživatele.

    Ladislav Hagara | Komentářů: 0
    dnes 00:22 | Nová verze

    Byla vydána betaverze Fedora Linuxu 44 (ChangeSet), tj. poslední zastávka před vydáním finální verze, která je naplánována na úterý 14. dubna.

    Ladislav Hagara | Komentářů: 0
    včera 12:11 | IT novinky

    Open source router Turris Omnia NG Wired je v prodeji. Jedná se o Turris Omnia NG bez Wi-Fi. Je připraven pro zamontování do racku.

    Ladislav Hagara | Komentářů: 6
    včera 11:44 | Pozvánky

    Sníh roztál a roztávají i bastlíři. Žene se na nás celá řada konferencí a seminářů technického rázu. Zajímá vás, jaké? Pak se připojte k 60. Virtuální Bastlírně, tedy k veřejné diskuzi bastlířů, techniků, učitelů i vědců. Jako vždy přijde na přetřes spousta novinek ze světa hardwaru, softwaru i bizáru. Na začátek lze očekávat hardwarová témata, tedy například nový KiCAD 10, nové akcelerátory LLM s nízkou spotřebou, nejvíce fosforeskující

    … více »
    bkralik | Komentářů: 1
    včera 11:22 | Zajímavý článek

    IuRe (Iuridicum Remedium) v rámci programu Digitální svobody zveřejnila analýzu dopadů a efektivity systémů ověřování věku v digitálním prostoru, která srovnává implementace ověřování věku v Austrálii, Velké Británii a Evropské unii.

    |🇵🇸 | Komentářů: 1
    včera 04:22 | Nová verze

    Multiplatformní emulátor terminálu Ghostty byl vydán ve verzi 1.3 (𝕏, Mastodon). Přehled novinek a vylepšení v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    včera 03:55 | Nová verze

    Byla vydána nová verze 14.4 svobodného unixového operačního systému FreeBSD. Podrobný přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 5
    9.3. 23:22 | Nová verze

    Databáze DuckDB (Wikipedie) byla vydána ve verzi 1.5.0. S kódovým názvem Variegata (husice rajská). Přináší řadu vylepšení, včetně nového ergonomičtějšího CLI klienta nebo podporu pro typ VARIANT a vestavěný typ GEOMETRY.

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (16%)
     (6%)
     (0%)
     (11%)
     (29%)
     (2%)
     (5%)
     (2%)
     (13%)
     (25%)
    Celkem 1053 hlasů
     Komentářů: 25, poslední 3.2. 19:50
    Rozcestník

    Dotaz: vypsat řádky se stejným polem z cvs souboru

    6.12.2012 19:16 hajoucha | skóre: 22
    vypsat řádky se stejným polem z cvs souboru
    Přečteno: 395×
    Ahojda, mám soubor cvs (comma separated value) a potřebuji vypsat řádky, na kterých je stejná třetí položka. Jak na to nejlépe? Dokážu pomocí awk, sort a uniq -d vypsat příslušné položky, ale bohužel právě jenom ty položky, nikoliv celý řádek. Řádků bude nejvýše 2200 a budou dlouhé max 150 znaků.

    Řešení dotazu:


    Odpovědi

    6.12.2012 20:19 rastos | skóre: 63 | blog: rastos
    Rozbalit Rozbalit vše Re: vypsat řádky se stejným polem z cvs souboru
    Čo myslíš tým 'stejná'? Ak tým myslíš, riadky ktoré majú napr. v 2. stĺpci slovo 'foo' tak:

    awk -F , '{ if ( $2 == "foo" ) print $0 } ' < sbor.csv
    6.12.2012 23:01 hajoucha | skóre: 22
    Rozbalit Rozbalit vše Re: vypsat řádky se stejným polem z cvs souboru
    myslím tím řádky typu:
    ahoj, prase, jsi, tu?
    nazdar, prase, nejsem.
    
    běžela, liška, polem
    tahle, liška, je, mazaná
    
    
    Tj. když se v souboru vyskytují řádky se stejnou druhou položkou, tak je vypsat. Jde mi o to zjistit jestli, a které takové jsou.

    Taky by se dalo říct, že je potřeba soubor "seřadit podle druhé položky", pak "uniq -d taky podle druhé položky", ale tak, aby se vypsal celý řádek, nikoliv jenom druhá položka.
    6.12.2012 23:09 l4m4
    Rozbalit Rozbalit vše Re: vypsat řádky se stejným polem z cvs souboru
    Popis uniq ... aby se vypsal celý řádek, nikoliv jenom druhá položka nedává tak úplně smysl.

    Buď chceš vypsat každou unikátní druhou položku právě jednou -- pak je zapotřebí definovat, který konkrétní z mnoha řádků, na kterých se vyskytuje, se má vypsat.

    Nebo chceš vypsat všechny takové řádky, ale pak ta operace neobsauje žádný uniq, je to prostě sort -t, -k2.
    7.12.2012 07:16 hajoucha | skóre: 22
    Rozbalit Rozbalit vše Re: vypsat řádky se stejným polem z cvs souboru
    jo, nebyl to šťastný nápad. uniq to prostě neumí, neměl jsem to zmiňovat.

    sort -t, -k2 seřadí ten soubor, ale vypíše ho celý. Já bych rád vypsal jenom ty řádky, jejichž druhé pole není v souboru unikátní.
    6.12.2012 23:22 Kit
    Rozbalit Rozbalit vše Re: vypsat řádky se stejným polem z cvs souboru
    Vytvoř si asociativní pole. V cyklu přečti ze vstupu jeden řádek a vyber z něj klíč. Pokud je klíč již obsažen v poli, vypiš záznam z pole i řádek ze vstupu. V opačném případě přidej záznam do pole[klíč].

    Nejlépe to půjde asi s AWK.
    7.12.2012 00:02 František Bublík | skóre: 16
    Rozbalit Rozbalit vše Re: vypsat řádky se stejným polem z cvs souboru
    A co takle?

    cut -d";" -f4 soubor.csv | grep prase

    (v případě, že delimiter je středník) :-)
    7.12.2012 07:12 hajoucha | skóre: 22
    Rozbalit Rozbalit vše Re: vypsat řádky se stejným polem z cvs souboru
    nevím dopředu, co mám grepovat. Chci najít duplicity, nevím kolik jich je, ani jaké jsou.
    7.12.2012 07:20 hajoucha | skóre: 22
    Rozbalit Rozbalit vše Re: vypsat řádky se stejným polem z cvs souboru
    tohle vypadá slibně, díky! Vyzkouším to.
    7.12.2012 14:11 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: vypsat řádky se stejným polem z cvs souboru
    Jestli je to obecné CSV-čko, tak aby to bylo zábavné tak:
    běžela," červená, malá a ""drzá"" liška", zoraným, polem
    tahle," červená, malá a hubatá liška", je, mazaná.
    
    jsou dva záznamy o čtyřech sloupcích, takže parser řádku musí být trochu „chytřejší“.
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    7.12.2012 14:28 Kit
    Rozbalit Rozbalit vše Re: vypsat řádky se stejným polem z cvs souboru
    Pokud by to mělo být obecné CSV, tak bych použil asi raději PHP.
    7.12.2012 12:51 marek
    Rozbalit Rozbalit vše Re: vypsat řádky se stejným polem z cvs souboru
    Dobry den.

    pomoci napr. "awk, sort a uniq -d" ziskate jednotlive polozky, potom holt "man join".

    Marek
    Řešení 1× (hajoucha (tazatel))
    7.12.2012 14:47 Vojtěch Horký | skóre: 39 | blog: Vojtův zápisník | Praha
    Rozbalit Rozbalit vše Re: vypsat řádky se stejným polem z cvs souboru
    csvfix unique -f 3 -d
    I am always ready to learn although I do not always like to be taught. (W. Churchill)
    7.12.2012 17:09 hajoucha | skóre: 22
    Rozbalit Rozbalit vše Re: vypsat řádky se stejným polem z cvs souboru
    paráda, funguje báječně, díky!

    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.