abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 02:33 | Zajímavý článek

    Jak nahrávat zvuk z webového prohlížeče na Linuxu s PipeWire pomocí Nahrávání zvuku (Sound Recorder) a Helvum případně qpwgraph, článek na webu Libre Arts.

    Ladislav Hagara | Komentářů: 0
    včera 22:11 | Komunita

    Vývoj webového serveru a reverzní proxy nginx byl přesunut z Mercurial na GitHub.

    Ladislav Hagara | Komentářů: 1
    včera 17:44 | Nová verze

    Open source platforma Home Assistant (Demo, GitHub, Wikipedie) pro monitorování a řízení inteligentní domácnosti byla vydána ve verzi 2024.9.

    Ladislav Hagara | Komentářů: 1
    včera 17:22 | Bezpečnostní upozornění

    České bezpečnostní instituce, jmenovitě Vojenské zpravodajství (VZ) a Bezpečnostní informační služba (BIS), ve spolupráci s americkou Agenturou pro kybernetickou a infrastrukturní bezpečnost (CISA), Federálním úřadem pro vyšetřování (FBI), Národní bezpečností agenturou (NSA) a dalšími mezinárodními partnery ze Spojeného království, Austrálie, Kanady, Německa, Nizozemska, Estonska, Ukrajiny a Lotyšska vydaly upozornění (

    … více »
    Ladislav Hagara | Komentářů: 13
    včera 03:00 | Nová verze

    Byla vydána (𝕏) srpnová aktualizace aneb nová verze 1.93 editoru zdrojových kódů Visual Studio Code (Wikipedie). Přehled novinek i s náhledy a animovanými gify v poznámkách k vydání. Ve verzi 1.93 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.

    Ladislav Hagara | Komentářů: 0
    včera 02:00 | IT novinky

    Společnost Laravel stojící za stejnojmenným open source PHP frameworkem získala investici 57 milionů dolarů od společnosti Accel. Především na Laravel Cloud.

    Ladislav Hagara | Komentářů: 2
    včera 01:00 | Nová verze

    Byla vydána verze 1.81.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání. Řešena je také zranitelnost CVE-2024-43402. Vyzkoušet Rust lze například na stránce Rust by Example.

    Ladislav Hagara | Komentářů: 0
    5.9. 17:11 | Nová verze

    Vládní CERT vydal (𝕏) novou verzi nástroje maldump. Ten slouží k extrakci souborů z karantén různých antivirových programů. A to jak z živého systému, tak z obrazu disku.

    Ladislav Hagara | Komentářů: 8
    5.9. 16:44 | Pozvánky

    Meeting ESP komunity - podzimní edice 2024 proběhne v pátek 18. října v Brně. V přípravě jsou přednášky od vývojářů z Espressifu, lokálních firem i zapálených nadšenců do ESP a také praktický workshop a ukázky nových čipů.

    Ladislav Hagara | Komentářů: 0
    5.9. 14:11 | Nová verze

    Systém pro správu hlášení chyb Bugzilla byl podle plánu vydán v nových verzích 5.2, 4.4.14, 5.0.4.1, 5.3.3 a 5.9.1, kde 5.2 představuje novou stabilní řadu, 4.4.14 by měla být poslední ve staré řadě 4.4, jíž končí podpora na přelomu roku, 5.0.4.1 je udržovací opravné vydání staré řady 5.0, dosavadní stabilní řada 5.1 byla přejmenována na 5.3 (nyní 5.3.3) a konečně vývojová verze 5.9.1 směřuje k budoucímu velkému vydání Bugzilly 6.

    Fluttershy, yay! | Komentářů: 0
    Rozcestník

    Dotaz: Skript na "prerozdelenie dát" v CSV

    7.4.2010 15:49 Peter
    Skript na "prerozdelenie dát" v CSV
    Přečteno: 270×

    Dobrý deň prajem.

    Mám jeden veľký CSV súbor (cca 1.000.000 záznamov) ktorý vyzerá takto:

    "poradove_cislo","Priezvisko Meno","Titul","PSČ","Mesto","Ulica","číslo_domu","Telefón"

    a ja ho potrebujem mať takto:

    "Titul","Meno","Priezvisko","Telefón","Ulica číslo_domu","Mesto","PSČ"

    Ide hlavne o to, že hlavne potrebujem "rozdeliť" sĺpec ("Priezvisko Meno") na ("Meno","Priezvisko") a "spojiť" sĺpce ("Ulica","číslo_domu") na ("Ulica číslo_domu").

    Absolútne ale nemám potuchy, že kde začať a aké CLI nástroje na to použíť. Preto od vás drzo prosím ilustračný príklad. :-D

    Vopred veľmi pekne ďakujem.


    Řešení dotazu:


    Odpovědi

    7.4.2010 16:09 Petr Šobáň | skóre: 80 | blog: soban | Olomouc
    Rozbalit Rozbalit vše Re: Skript na "prerozdelenie dát" v CSV
    A to je nějakej problém si v cyklu načíst ty proměnné a zapsat je do druhého souboru a pak ten starý smazat a nový přejmenovat?

    Nebo kde je problém ?
    7.4.2010 17:01 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: Skript na "prerozdelenie dát" v CSV
    Pokud je CSV generováno a je striktně dodrženo, že mezi čárkou a uvozovkami není mezera a jedná se jen o jeden převod, tak přes editor vi(m) (soubor bude tak do 200MiB a to se zvládne na běžném PC):
    cp muj.csv out.csv
    vim out.csv
    
    a ve víčku zadat (zapsat znak ':' a pak zkopírovat zbytek):
    :%s/^"\([^",]*\)","\([^",]*\)\ \([^",]*\)","\([^",]*\)","\([^",]*\)","\([^",]*\)","\([^",]*\)","\([^",]*\)","\([^",]*\)"$/"\4","\3","\2","\9","\7 \8","\6","\5"/g
    
    asi chvilku počkat
    a pak třeba:
    :wq
    
    Samozřejně RegExpr se dá použít kdekoliv a jakkoliv je upravit.:)
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    7.4.2010 17:09 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: Skript na "prerozdelenie dát" v CSV
    Sorry, nevím na co myslím, opravička:
    :%s/^"\(.*\)","\(.*\)\ \(.*\)","\(.*\)","\(.*\)","\(.*\)","\(.*\)","\(.*\)","\(.*\)"$/"\4","\3","\2","\9","\7 \8","\6","\5"/g
    
    Bude rozhodně lepší :)
    CSV může mít uvozovky mezi uvozovkami (zapsány zdvojeně) a samozřejmě může být mezi uvozovkami čárka.
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    Tarmaq avatar 7.4.2010 17:57 Tarmaq | skóre: 39
    Rozbalit Rozbalit vše Re: Skript na "prerozdelenie dát" v CSV
    Proc to psat ve vimu? Neni lepsi na to pouzit sed? Vzdyt to je uplne stejne..
    $ cat foo 
    "poradove_cislo","Priezvisko Meno","Titul","PSC","Mesto","Ulica","cislo_domu","Telefon"
    $ sed 's/^"\(.*\)","\(.*\)\ \(.*\)","\(.*\)","\(.*\)","\(.*\)","\(.*\)","\(.*\)","\(.*\)"$/"\4","\3","\2","\9","\7 \8","\6","\5"/g' foo 
    "Titul","Meno","Priezvisko","Telefon","Ulica cislo_domu","Mesto","PSC"
    
    Don't panic!
    7.4.2010 18:03 Peter
    Rozbalit Rozbalit vše Re: Skript na "prerozdelenie dát" v CSV
    Samozrejme, že aj toto funguje perfektne. Chlapci - vrelá vďaka, aspoň som si rozšíril obzory s regexp.
    7.4.2010 18:39 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: Skript na "prerozdelenie dát" v CSV
    No čekal jsem, že to někdo stihne napsat dřív… :)

    Odpověď na Vaše otázky je jednoduchá, v obráceném pořadí:
    Za daných okolností „není“ :)
    a tady je odpověď na to „proč“ :):
    Důležité je to RegExp a je jedno kde jej použijete a ve víčku si to můžete opakovaně zkoušet a ladit a okamžitě vidět výsledek (třeba jen na jednom řádku). Takže mi přijde pro přípravu a první naladění víčko lepší.
    Pokud to tam už naladím, tak to sjedu na celý text a uložím to a je to.
    Pokud by se to mělo často opakovat, je to jiné téma.
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    8.4.2010 08:45 dustin | skóre: 63 | blog: dustin
    Rozbalit Rozbalit vše Re: Skript na "prerozdelenie dát" v CSV
    Souhlasím, také to raději ladím ve vimu se zapnutým zvýrazňováním nalezeného textu, s pomocí undo a historie příkazů je to mnohem rychlejší
    7.4.2010 17:59 Peter
    Rozbalit Rozbalit vše Re: Skript na "prerozdelenie dát" v CSV
    Ty si môj hrdina. Vrelá, vrelá vrelá vďaka. :-D

    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.