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

Byl vydán Mozilla Firefox 51.0. Z novinek lze upozornit například na upozorňování na přihlašování přes nešifrované spojení (HTTP), podporu pro přehrávání bezeztrátového formátu FLAC nebo podporu WebGL 2. Podrobné informace v poznámkách k vydání a na stránce věnované vývojářům. Řešeny jsou také bezpečnostní chyby.

Ladislav Hagara | Komentářů: 2
23.1. 17:25 | IT novinky

Do prodeje (Farnell) se dostal jednodeskový počítač Tinker Board (unboxing). Jedná se o konkurenci Raspberry Pi 3 od společnosti Asus. Porovnání (jpg) těchto počítačů například na CNXSoft. Cena Tinker Boardu je 55 £.

Ladislav Hagara | Komentářů: 15
23.1. 14:44 | Zajímavý projekt

Byla zveřejněna pravidla hackerské soutěže Pwn2Own 2017, jež proběhne od 15. do 17. března v rámci bezpečnostní konference CanSecWes ve Vancouveru. Soutěžit se bude o více než milion dolarů v pěti kategoriích. Letos se bude útočit i na Ubuntu. Jedná se již o 10. ročník této soutěže.

Ladislav Hagara | Komentářů: 2
23.1. 13:33 | Nová verze

Po sedmi měsících vývoje od vydání verze 5.7 byla vydána verze 5.8 (YouTube) toolkitu Qt. Z novinek lze zmínit například Qt Lite pro vestavěná zařízení. Nově jsou plně podporovány moduly Qt Wayland Compositor (YouTube) a Qt SCXML (YouTube). Současně byla vydána verze 4.2.1 integrovaného vývojového prostředí (IDE) Qt Creator.

Ladislav Hagara | Komentářů: 1
23.1. 11:52 | Pozvánky

Lednový Prague Containers Meetup se koná ve čtvrtek 26. ledna 2017 od 18:00 v Apiary, Pernerova 49, Praha 8. Přijďte se podívat na přednášky o Enterprise Kubernetes a Jenkins as a code.

little-drunk-jesus | Komentářů: 0
23.1. 11:40 | Pozvánky

Program letošního ročníku konference Prague PostgreSQL Developer Days, která se koná již 15. a 16. února 2017 na ČVUT FIT, Thákurova 9, Praha 6, byl dnes zveřejněn. Najdete ho na stránkách konference včetně anotací přednášek a školení. Registrace na konferenci bude otevřena zítra (24. ledna) v brzkých odpoledních hodinách.

TomasVondra | Komentářů: 0
22.1. 02:20 | Zajímavý článek

David Revoy, autor open source webového komiksu Pepper&Carrot nebo portrétu GNU/Linuxu, upozorňuje na svém blogu, že nový Inkscape 0.92 rozbíjí dokumenty vytvořené v předchozích verzích Inkscape. Problém by měl být vyřešen v Inkscape 0.92.2 [reddit].

Ladislav Hagara | Komentářů: 0
22.1. 02:02 | Komunita

Øyvind Kolås, hlavní vývojář grafických knihoven GEGL a babl, které využívá grafický program GIMP, žádá o podporu na Patreonu. Díky ní bude moci pracovat na vývoji na plný úvazek. Milník 1000 $, který by stačil na holé přežití, se již téměř podařilo vybrat, dalším cílem je dosažení 2500 $, které mu umožní běžně fungovat ve společnosti.

xkomczax | Komentářů: 12
21.1. 23:54 | Pozvánky

DevConf.cz 2017, již devátý ročník jedné z největších akcí zaměřených na Linux a open source ve střední Evropě, proběhne od pátku 27. ledna do neděle 29. ledna v prostorách Fakulty informačních technologií Vysokého učení technického v Brně. Na programu je celá řada zajímavých přednášek a workshopů. Letos je povinná registrace.

Ladislav Hagara | Komentářů: 0
21.1. 22:11 | Nová verze

Byla vydána verze 1.0.0 emulátoru terminálu Terminology postaveného nad EFL (Enlightenment Foundation Libraries). Přehled novinek v poznámkách k vydání.

Ladislav Hagara | Komentářů: 0
Jak se stavíte k trendu ztenčování přenosných zařízení (smartphony, notebooky)?
 (12%)
 (2%)
 (72%)
 (3%)
 (11%)
Celkem 395 hlasů
 Komentářů: 39, poslední včera 19:30
Rozcestník
Reklama

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

6.12.2012 19:16 hajoucha | skóre: 21
vypsat řádky se stejným polem z cvs souboru
Přečteno: 254×
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: 60 | 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: 21
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: 21
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: 15
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: 21
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: 21
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: 21
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.