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

    Byla vydána nová verze 2025.4 linuxové distribuce navržené pro digitální forenzní analýzu a penetrační testování Kali Linux (Wikipedie). Přehled novinek se seznamem nových nástrojů v oficiálním oznámení na blogu.

    Ladislav Hagara | Komentářů: 0
    dnes 12:44 | IT novinky

    Národní úřad pro kybernetickou a informační bezpečnost (NÚKIB) zveřejnil Národní politiku koordinovaného zveřejňování zranitelností (pdf), jejímž cílem je nejen zvyšování bezpečnosti produktů informačních a komunikačních technologií (ICT), ale také ochrana objevitelů zranitelností před negativními právními dopady. Součástí je rovněž vytvoření „koordinátora pro účely CVD“, jímž je podle nového zákona o kybernetické … více »

    Ladislav Hagara | Komentářů: 3
    dnes 04:33 | Nová verze

    Vývojáři KDE oznámili vydání balíku aplikací KDE Gear 25.12. Přehled novinek i s náhledy a videi v oficiálním oznámení.

    Ladislav Hagara | Komentářů: 0
    dnes 03:55 | Nová verze

    Společnost System76 vydala Pop!_OS 24.04 LTS s desktopovým prostředím COSMIC. Videoukázky na YouTube.

    Ladislav Hagara | Komentářů: 0
    dnes 03:11 | Nová verze

    Byla vydána verze 1.92.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání. Vyzkoušet Rust lze například na stránce Rust by Example.

    Ladislav Hagara | Komentářů: 0
    dnes 01:33 | Komunita

    Free Software Foundation zveřejnila ocenění Free Software Awards za rok 2024. Oceněni byli Andy Wingo, jeden ze správců GNU Guile, Alx Sa za příspěvky do Gimpu a Govdirectory jako společensky prospěšný projekt.

    |🇵🇸 | Komentářů: 3
    včera 18:55 | Nová verze

    Bylo vydáno Eclipse IDE 2025-12 aneb Eclipse 4.38. Představení novinek tohoto integrovaného vývojového prostředí také na YouTube.

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

    U příležitosti oslav osmi let prací na debianím balíčku vyšlo GPXSee 15.6. Nová verze přináší především podporu pro geotagované MP4 soubory, včetně GoPro videí. Kdo nechce čekat, až nová verze dorazí do jeho distribuce, nalezne zdrojové kódy na GitHubu.

    Martin Tůma | Komentářů: 14
    včera 09:22 | Nová verze

    Monado, tj. multiplatformní open source implementace standardu OpenXR specifikujícího přístup k platformám a zařízením pro XR, tj. platformám a zařízením pro virtuální realitu (VR) a rozšířenou realitu (AR), bylo vydáno ve verzi 25.1.0. Přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    včera 02:44 | Nová verze

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

    Ladislav Hagara | Komentářů: 0
    Jaké řešení používáte k vývoji / práci?
     (34%)
     (47%)
     (19%)
     (17%)
     (22%)
     (15%)
     (24%)
     (15%)
     (17%)
    Celkem 458 hlasů
     Komentářů: 19, poslední včera 20:04
    Rozcestník

    Dotaz: Zpracovani textu pomoci AWK

    1.3.2008 11:27 Adam Koutny
    Zpracovani textu pomoci AWK
    Přečteno: 360×
    Dobry den, resim problem ohledne zpracovani textu pod linuxem (tedy chci pouzit std unix. utility jako cat, sed, awk...)

    mam dva soubory, prvni (a.txt) ma takovyto obsah:
    A:10
    B:30
    D:33
    
    druhy (b.txt) vypada takto:
    1:3:8:2:5:19
    Cisla v druhem souboru reprezentuji toto:

    1 = A 3 = B ... 5 = E 19 = suma(A-E)

    Ja bych potreboval soubor b.txt upravit podle prvniho souboru aby vypadal takto:
    10:30:8:33:5:86
    tzn hodnoty pismen, ktere se nachazeji v souboru a.txt (tedy A,B,D) prenesu na urcenou pozici v souboru b.txt a ty hodnoty (napr C), ktere se v prvnim souboru nenachazeji, ty v druhem souboru ponecham. Nakonec jeste zbyva vypocitat novou sumu.

    Zacal jsem se ucit jazyk awk, ten je podle meho nazoru na tuto operaci idealni. Stale vsak nejak nemohu prijit na to, jak to cele provest. Perl ani python pouzit nechci. Budu rad za vsechny rady, dekuji.

    Odpovědi

    1.3.2008 12:14 Miška | skóre: 31 | Praha
    Rozbalit Rozbalit vše Re: Zpracovani textu pomoci AWK
    cca +-
    #!/bin/sh
    cat a.txt | tr [A-F] [1-6] | sed 's|\([0-9]\):\([0-9]*\)|s:\1:\2:g|' > /tmp/tempfile.$$
    SUM="`cat b.txt | sed -f /tmp/tempfile.$$`"
    POM="`echo $SUM | sed 's|:|\ +\ |' | sed 's|+[0-9]*$||'`"
    SUM="$SUM:`expr $POM`"
    echo "$SUM" > b.txt
    rm -f /tmp/tempfile.$$
    
    1.3.2008 12:46 chearius | skóre: 7 | blog: /dev/chearius | Heidelberg
    Rozbalit Rozbalit vše Re: Zpracovani textu pomoci AWK
    Ten skript bohuzel nefunguje vzdycky spravne. V pripade, ze budou v souboru b.txt dve stejne hodnoty, tak je vysledek spatne. Napriklad:

    a.txt
    A:10
    B:30
    D:33
    
    a b.txt
    1:1:8:2:5:17
    
    vrati vas skript vysledek:
    10:10:8:30:5:107:
    
    Spravny vysledek by ale mel podle mne byt
    10:30:8:33:5:86
    
    Problem prave v tech substitucich ukladanych do toho docasneho souboru.
    1.3.2008 12:22 chearius | skóre: 7 | blog: /dev/chearius | Heidelberg
    Rozbalit Rozbalit vše Re: Zpracovani textu pomoci AWK
    V awk by se to dalo resit treba takto (neni to idealni reseni, ale funguje):
    BEGIN {
                    FS = ":";
                    cells = "ABCDEFGHIJKLMNOPQRSTUVWXYZ";
                    for (i = 0; i < length(cells); i++)
                            values[i] = "nan";
            }
    
    /^[A-Z][:][0-9]+$/ {
                    ind = index(cells, $1) - 1;
                    if (ind >= 0)
                            values[ind] = $2;
    
            }
    
    /^([0-9]+[:]?)+$/ {
                    result = "";
                    sum = 0;
    
                    for (i = 0; i < NF - 1; i++) {
                            if (match(values[i], /[0-9]+/) > 0) {
                                    result = result values[i] ":";
                                    sum += values[i];
                            } else {
                                    result = result $(i + 1) ":";
                                    sum += $(i + 1);
                            }
                    }
    
                    result = result sum;
                    print result;
            }
    ~
    
    A pak to spustit pomoci awk -f vypocet.awk a.txt b.txt.

    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.