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:11 | Komunita

    V Berlíně probíhá konference vývojářů a uživatelů desktopového prostředí KDE Plasma Akademy 2025. Při té příležitosti byla oznámena alfa verze nové linuxové distribuce KDE Linux.

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

    Byl vydán Debian 13.1, tj. první opravná verze Debianu 13 s kódovým názvem Trixie a Debian 12.12, tj. dvanáctá opravná verze Debianu 12 s kódovým názvem Bookworm. Řešeny jsou především bezpečnostní problémy, ale také několik vážných chyb. Instalační média Debianu 13 a Debianu 12 lze samozřejmě nadále k instalaci používat. Po instalaci stačí systém aktualizovat.

    Ladislav Hagara | Komentářů: 0
    5.9. 23:44 | IT novinky

    Evropská komise potrestala Google ze skupiny Alphabet pokutou 2,95 miliardy eur (71,9 miliardy Kč) za porušení antimonopolní legislativy. Podle EK, která mimo jiné plní funkci antimonopolního orgánu EU, se Google dopustil protisoutěžních praktik ve svém reklamním byznysu. Google v reakci uvedl, že rozhodnutí považuje za chybné a hodlá se proti němu odvolat. EK ve věci rozhodovala na základě stížnosti Evropské rady vydavatelů. Podle

    … více »
    Ladislav Hagara | Komentářů: 9
    5.9. 23:11 | Komunita

    Podpora 32bitového Firefoxu pro Linux skončí v roce 2026. Poslední podporované 32bitové verze budou Firefox 144 a Firefox 140 s rozšířenou podporou, jehož podpora skončí v září 2026.

    Ladislav Hagara | Komentářů: 2
    5.9. 19:33 | IT novinky

    Společnost Raspberry Pi nově nabízí Raspberry Pi SSD s kapacitou 1 TB za 70 dolarů.

    Ladislav Hagara | Komentářů: 7
    5.9. 15:55 | Zajímavý software

    Microsoft BASIC pro mikroprocesor 6502 byl uvolněn jako open source. Zdrojový kód je k dispozici na GitHubu.

    Ladislav Hagara | Komentářů: 5
    5.9. 15:33 | IT novinky

    Národní úřad pro kybernetickou a informační bezpečnost (NÚKIB) se připojil k dokumentu „A Shared Vision of Software Bill of Materials (SBOM) for Cybersecurity“, který vydala americká Agentura pro kybernetickou a infrastrukturní bezpečnost (CISA) s Národní bezpečnostní agenturou (NSA), spolu s dalšími mezinárodními partnery. Dokument vznikl v rámci globálního expertního fóra pro SBOM, které má za cíl motivovat k širšímu využívání … více »

    Ladislav Hagara | Komentářů: 3
    4.9. 21:22 | IT novinky

    Švýcarská AI centra EPFL, ETH Zurich a CSCS představila otevřený vícejazyčný velký jazykový model (LLM) s názvem Apertus. Vyzkoušet lze na stránce Public AI Inference Utility.

    Ladislav Hagara | Komentářů: 26
    4.9. 17:22 | Nová verze

    Byl vydán Linux Mint 22.2 s kódovým jménem Zara. Podrobnosti v přehledu novinek a poznámkách k vydání. Vypíchnout lze novou XApp aplikaci Fingwit pro autentizaci pomocí otisků prstů nebo vlastní fork knihovny libAdwaita s názvem libAdapta podporující grafická témata. Linux Mint 22.2 bude podporován do roku 2029.

    Ladislav Hagara | Komentářů: 1
    4.9. 12:55 | IT novinky

    Čínská společnost Tencent uvolnila svůj AI model HunyuanWorld-Voyager pro generování videí 3D světů z jednoho obrázku a určené trajektorie kamery. Licence ale nedovoluje jeho používání na území Evropské unie, Spojeného království a Jižní Koreje.

    Ladislav Hagara | Komentářů: 1
    Pro otevření více webových stránek ve webovém prohlížečí používám
     (83%)
     (7%)
     (2%)
     (3%)
     (3%)
     (2%)
    Celkem 150 hlasů
     Komentářů: 11, poslední 4.9. 16:12
    Rozcestník

    Dotaz: Zpracovani textu pomoci AWK

    1.3.2008 11:27 Adam Koutny
    Zpracovani textu pomoci AWK
    Přečteno: 327×
    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.