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 06:00 | Zajímavý článek

    Nové číslo časopisu Raspberry Pi zdarma ke čtení: Raspberry Pi Official Magazine 162 (pdf).

    Ladislav Hagara | Komentářů: 0
    dnes 05:55 | IT novinky

    Sdružení CZ.NIC, správce české národní domény, zveřejnilo Domain Report za rok 2025 s klíčovými daty o vývoji domény .CZ. Na konci roku 2025 bylo v registru české národní domény celkem 1 515 860 s koncovkou .CZ. Průměrně bylo měsíčně zaregistrováno 16 222 domén, přičemž nejvíce registrací proběhlo v lednu (18 722) a nejméně pak v červnu (14 559). Podíl domén zabezpečených pomocí technologie DNSSEC se po několika letech stagnace výrazně

    … více »
    Ladislav Hagara | Komentářů: 3
    včera 18:33 | IT novinky

    Google představil telefon Pixel 10a. S funkci Satelitní SOS, která vás spojí se záchrannými složkami i v místech bez signálu Wi-Fi nebo mobilní sítě. Cena telefonu je od 13 290 Kč.

    Ladislav Hagara | Komentářů: 3
    včera 16:22 | Komunita

    Byl publikován přehled dění a novinek z vývoje Asahi Linuxu, tj. Linuxu pro Apple Silicon. Fedora 43 Asahi Remix s KDE Plasma už funguje na M3. Zatím ale bez GPU akcelerace. Vývojáře lze podpořit na Open Collective a GitHub Sponsors.

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

    Red Hat představil nový nástroj Digital Sovereignty Readiness Assessment (GitHub), který organizacím umožní vyhodnotit jejich aktuální schopnosti v oblasti digitální suverenity a nastavit strategii pro nezávislé a bezpečné řízení IT prostředí.

    Ladislav Hagara | Komentářů: 0
    včera 12:22 | Zajímavý software

    BarraCUDA je neoficiální open-source CUDA kompilátor, ale pro grafické karty AMD (CUDA je proprietární technologie společnosti NVIDIA). BarraCUDA dokáže přeložit zdrojové *.cu soubory (prakticky C/C++) přímo do strojového kódu mikroarchitektury GFX11 a vytvořit tak ELF *.hsaco binární soubory, spustitelné na grafické kartě AMD. Zdrojový kód (převážně C99) je k dispozici na GitHubu, pod licencí Apache-2.0.

    NUKE GAZA! 🎆 | Komentářů: 1
    17.2. 17:00 | IT novinky

    Podvodné reklamy na sociálních internetových platformách, jako je Facebook, Instagram nebo X, vytvořily loni v Česku jejich provozovatelům příjmy 139 milionů eur, tedy zhruba 3,4 miliardy korun. Proti roku 2022 je to nárůst o 51 procent. Vyplývá to z analýzy Juniper Research pro společnost Revolut. Podle výzkumu je v Česku zhruba jedna ze sedmi zobrazených reklam podvodná. Je to o 14,5 procenta více, než je evropský průměr, kde je podvodná každá desátá reklama.

    Ladislav Hagara | Komentářů: 9
    17.2. 15:44 | Nová verze

    Desktopové prostředí KDE Plasma bylo vydáno ve verzi 6.6 (Mastodon). Přehled novinek i s videi a se snímky obrazovek v oficiálním oznámení. Podrobný přehled v seznamu změn.

    Ladislav Hagara | Komentářů: 0
    17.2. 03:22 | Nová verze

    Czkawka a Krokiet, grafické aplikace pro hledání duplicitních a zbytečných souborů, byly vydány ve verzi 11.0. Podrobný přehled novinek v příspěvku na Medium. Od verze 7.0 je vedle frontendu Czkawka postaveného nad frameworkem GTK 4 vyvíjen nový frontend Krokiet postavený nad frameworkem Slint. Frontend Czkawka je už pouze v udržovacím módu. Novinky jsou implementovány ve frontendu Krokiet.

    Ladislav Hagara | Komentářů: 27
    17.2. 02:00 | Zajímavý článek

    Jiří Eischmann na svém blogu publikoval článek Úvod do MeshCore: "Doteď mě radioamatérské vysílání úplně míjelo. Když jsem se ale dozvěděl, že existují komunity, které svépomocí budují bezdrátové sítě, které jsou nezávislé na Internetu a do značné míry taky elektrické síti a přes které můžete komunikovat s lidmi i na druhé straně republiky, zaujalo mě to. Když o tom přede mnou pořád básnili kolegové v práci, rozhodl jsem se, že to zkusím taky.

    … více »
    Ladislav Hagara | Komentářů: 4
    Které desktopové prostředí na Linuxu používáte?
     (18%)
     (6%)
     (0%)
     (11%)
     (27%)
     (3%)
     (4%)
     (2%)
     (12%)
     (27%)
    Celkem 904 hlasů
     Komentářů: 25, poslední 3.2. 19:50
    Rozcestník

    Dotaz: Automaticke porovnani a oznaceni odlisnosti v txt souboru

    tomes.io avatar 3.8.2012 15:05 tomes.io | skóre: 12 | blog: tomesh
    Automaticke porovnani a oznaceni odlisnosti v txt souboru
    Přečteno: 485×
    Ahoj,

    mam dva textove soubory a oba potrebuju skriptem porovnat radek po radku tak, aby skript nestejne radky oznacil.

    Tak me napadlo ze
     diff -c 
    oznaci radky, ktere jsou jine, vykricnikem:(!) na zacatku radku.

    No a napadlo me brat dycky radek po radku z kazdeho souboru do nejakeho tmp (tmp='tmpfile' kvuli bezpecnosti), ty porovnat diffem, pokud je radek stejny, tak appendnout
    >>
    do tmp souboru, pokud je radek jiny, diff ho oznaci a taky (oznaveny) radek pripne do tmp soubor. Pak tmp prepise puvodni soubor.

    Pseudoskript by vypadal nejak takto:
    #!/bin/bash
    while read line; do 
        echo $line > tmp          #vezme radek
                                  #zde porovnava s druhym, ale jak, nejakou vhodnou funkci?
        cat tmp >> temporary      #pripina do dalsiho docasneho postupne radek po radku, vcetne oznacenych
    done < "sample.txt"
    Byl bych rad, kdyby me nekdo nakopnul spravnym smerem.


    Řešení dotazu:


    Odpovědi

    3.8.2012 15:26 NN
    Rozbalit Rozbalit vše Re: Automaticke porovnani a oznaceni odlisnosti v txt souboru
    Kvuli bezpecnosti brat radek po radku ?? Proc tedy neskopirovat rovnou cele soubory a porovnat je diffem ?
    tomes.io avatar 3.8.2012 17:26 tomes.io | skóre: 12 | blog: tomesh
    Rozbalit Rozbalit vše Re: Automaticke porovnani a oznaceni odlisnosti v txt souboru
    Sorry, tam melo byt kvuli bezpecnosti
    tmpfile=`mktemp`
    . Je lepsi pouzit mktemp nez vytvoreni noveho docasneho souboru (kvuli symlink vulnerability). Pro potreby pseudokodu je to vsak irelevantni (navic mktemp umozni bezproblemove spusteni skriptu na jednom pocitaci vicekrat).

    Kdyby slo porovnat soubory diffem tak, aby mi tako vystup hodil jiz oznacene soubory, bylo by to fajn. Ale nevim, jak to udelat, nikde jsem takovou moznost nevygooglil, proto me napadl ten postup s porovnanim radek po radku.

    Zkratka, kdyz mam v jednom souboru:
    aaaaa
    bbbbb
    a v druhem:
    aaaaa
    ccccc
    tak chci, aby vystup skriptu byly soubory, ve kterych by byly nejak oznacene radky, ktere se neshoduji, napr v prvnim souborU:
    aaaaa
    (!)bbbbb
    v druhem:
    aaaaa
    (!)ccccc
    3.8.2012 18:59 Patrik Uhrak | skóre: 31 | blog: pato
    Rozbalit Rozbalit vše Re: Automaticke porovnani a oznaceni odlisnosti v txt souboru
    #! /bin/bash
    
    input1="$1"
    input2="$2"
    
    while read line
    do
            if grep -e "$line" "$input2" &>/dev/null
            then
                    sed -i "s/$line/\!$line/" "$input1" "$input2"
            fi 
    done <./"$input1"
    

    Ako zaklad by to mohlo byt. Docasnymi subormi by som sa netrapil, iba to komplikuje vec. Staci spravit zalohu originalu pre spustenim skriptu.

    3.8.2012 19:03 Patrik Uhrak | skóre: 31 | blog: pato
    Rozbalit Rozbalit vše Re: Automaticke porovnani a oznaceni odlisnosti v txt souboru

    Treba opravit sed, lebo v danom skripte pri prvej zhode konci. Spravne to ma byt:

    sed -i "s/$line/\!$line/g" "$input1" "$input2"
    tomes.io avatar 7.8.2012 09:31 tomes.io | skóre: 12 | blog: tomesh
    Rozbalit Rozbalit vše Re: Automaticke porovnani a oznaceni odlisnosti v txt souboru
    Super, tohle me docela nakoplo, zbytek vyzjistim uz z manualu. Diky.
    tomes.io avatar 8.8.2012 14:33 tomes.io | skóre: 12 | blog: tomesh
    Rozbalit Rozbalit vše Re: Automaticke porovnani a oznaceni odlisnosti v txt souboru
    No tak to jako zaklad reseni selhava. neuvedomil jsem si, ze ten while bere pouze jeden radek z prvniho souboru.

    Prochazi WHILE soubor1, ale co ten soubor2? ten prece neprochazi radek po radku... Skript zkratka neudela vybec nic... neco jsem prehledl? Skrze ten cyklus to asi nepujde...
    8.8.2012 15:10 Patrik Uhrak | skóre: 31 | blog: pato
    Rozbalit Rozbalit vše Re: Automaticke porovnani a oznaceni odlisnosti v txt souboru

    Aj ste to skusali spustit ??? Bo robi to, co ste chceli. Ak porovnavam dva subory a hladam zhodu, tak ak sa prejde cely prvy subor riadok po riadku, tak nie je dovod kontrolovat kazdy riadok z druheho a porovnavat s riadkami v prvom subore.

    Vid ukazku:

    #! /bin/bash
     
    input1="$1"
    input2="$2"
     
    while read line
    do
            if grep -w -e "$line" "$input2" &>/dev/null
            then
                    sed -i "s/$line/\!$line/" "$input1" "$input2"
            fi
    done <"$input1"
    

    test2.file

    aaaaa
    fdsafasdsdafbbbbb
    cccccsfdsfsd
    fffffff
    gggggasfsdf
    hjlkk
    ewiorjodsfsdfsdf
    ad;kl
    jlkfsfafaf
    xxxxxxdfsdfaf
    

    test1.file

    aaaaa
    bbbbb
    ccccc
    fffffff
    ggggg
    hjlkk
    ewiorjo
    ad;kl
    jlk
    xxxxxx
    

    Po spusteni skriptu je vysledok nasledovny:

    Lucias-MacBook-Pro:~ lucka$ grep -n ^! test*.file
    test1.file:1:!aaaaa
    test1.file:2:!bbbbb
    test1.file:4:!fffffff
    test1.file:6:!h!jlkk
    test1.file:8:!ad;kl
    test2.file:1:!aaaaa
    test2.file:4:!fffffff
    test2.file:6:!h!jlkk
    test2.file:8:!ad;kl
    Lucias-MacBook-Pro:~ lucka$ grep -v -n ^! test*.file
    test1.file:3:ccccc
    test1.file:5:ggggg
    test1.file:7:ewiorjo
    test1.file:9:jlk
    test1.file:10:xxxxxx
    test2.file:2:fdsafasdsdaf!!bbbbb
    test2.file:3:cccccsfdsfsd
    test2.file:5:gggggasfsdf
    test2.file:7:ewiorjodsfsdfsdf
    test2.file:9:jlkfsfafaf
    test2.file:10:xxxxxxdfsdfaf
    

    Subory vyzeraju samozrejme inak, len som chcel ukazat zhody osve od riadkov, kde ku zhodam nedoslo, aby si si to mohol porovnat a videl dovod, preco je iba mrhanim prostriedkov konat inak.

    tomes.io avatar 8.8.2012 19:08 tomes.io | skóre: 12 | blog: tomesh
    Rozbalit Rozbalit vše Re: Automaticke porovnani a oznaceni odlisnosti v txt souboru
    Jasneze jsem to zkousel :) Ale v praci na win pres cygwin. Doma na Fedore to pracuje, takze se omlouvam za paniku. Fakt jsem myslel, ze je to ve spatnem cyklu . Takze uz to jede, sice to oznacuje shodne radky (chtel jsem neshodne) ale to je uz malickost.

    Horsi je, ze sed ma evifentne problem s tagy. Ja potrebuji takto porovnavat a oznacovat soubory, ktere maji jednu vetuna kazdem radku a kazda veta zacina < s > a konci < lomitko s>. Pdobne, jako mi zdejsi diskuse nepovoli ukoncovaci tag a musel jsem napsat slovy "lomitko" tak sed s tim ma taky problem:
    sed: -e expression #1, char 47: unknown option to `s'
    sed: -e expression #1, char 40: unknown option to `s'
    sed: -e expression #1, char 44: unknown option to `s'
    sed: -e expression #1, char 51: unknown option to `s'
    
    Jeda se vzdy o ukoncovaci tagy.

    Da se tohle nejak obejit?
    8.8.2012 22:10 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: Automaticke porovnani a oznaceni odlisnosti v txt souboru
    Proč neukážete i ten příkaz, který jste zkoušel? Takhle můžu jen hádat: tipuji problém s lomítkem, které bylo vyhodnoceno jako oddělovač, takže následující "s" sed chápal jako (neznámou) option. Je-li to tak, buď před to lomítko, které má být součástí vzorku, dejte backslash, nebo použijte jiný oddělovač, který nemáte ve vzorku ani v replacement textu.
    tomes.io avatar 8.8.2012 23:43 tomes.io | skóre: 12 | blog: tomesh
    Rozbalit Rozbalit vše Re: Automaticke porovnani a oznaceni odlisnosti v txt souboru
    Jaky prikaz mate na mysli? Spusteni skriptu? Ten povazuji za zrejmy:
    ]$ ./compare.sh file1.txt file2.txt
    sed: -e expression #1, char 84: unknown option to `s'
    sed: -e expression #1, char 28: unknown option to `s'
    sed: -e expression #1, char 74: unknown option to `s'
    
    Poukazuji na to, ze problem je v samotnych textovych souborech, ktere obsahuji tagy.

    Vypada to nejak takto:
    <s> veta </s>
    <s>druha veta </s>
    
    
    Soubory samotne modifikovat modifikovat nijak nemuzu, format vety uzavrenych mezi tagy musi zustat zachovan.

    tomes.io avatar 8.8.2012 23:44 tomes.io | skóre: 12 | blog: tomesh
    Rozbalit Rozbalit vše Re: Automaticke porovnani a oznaceni odlisnosti v txt souboru
    Snad by slo misto sed vyuzit awk.
    9.8.2012 06:40 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: Automaticke porovnani a oznaceni odlisnosti v txt souboru
    Jaky prikaz mate na mysli? Spusteni skriptu?

    Ne, pochopitelně příkaz sed, který vám tu chybu hlásí. Bez toho, abyste ukázal, s jakými parametry ho voláte, můžu jen hádat naslepo.

    9.8.2012 07:10 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: Automaticke porovnani a oznaceni odlisnosti v txt souboru
    Aha, on je to ten skript výše. Tak lomítko by ještě šlo ošetřit pomocí
      sed -e "s/^${line//\//\\/}$/\!&/"
    
    (stříška a dolar jsou nutné, aby to nenašlo i řádky, které obsahují řádek z prvního souboru jako podřetězec), ale stejně tam budou dělat problémy všechny ostatní konstrukce regulárních výrazů, např. tečka. Další chyba je v použití "read line", které odstraní počáteční a koncové mezery. A konečně se při upravování druhého souboru mění soubor, vůči kterému porovnáváme další řádky. Takže když už to dělat takhle, tak spíš
    #!/bin/bash
    
    matches1=`mktemp`
    matches2=`mktemp`
    
    i=1
    while read; do
        line="$REPLY"
    
         j=1
         while read; do
             if [ "$line" = "$REPLY" ]; then
                 echo $i >>"$matches1"
                 echo $j >>"$matches2"
             fi
             : $[j++]
         done <"$2"
    
        : $[i++]
    done <"$1"
    
    aux=`mktemp`
    prev=0
    exec 3<"$1"
    sort -n -u "$matches1" | while read next; do
        for ((i=prev; i<next; i++)); do
             read <&3
             echo "$REPLY" >>"$aux"
        done
        read <&3
        echo "!$REPLY" >>"$aux"
    done
    rm -f "$matches1"
    mv -f "$aux" "$1"
    
    aux=`mktemp`
    prev=0
    exec 3<"$2"
    sort -n -u "$matches2" | while read next; do
        for ((i=prev; i<next; i++)); do
             read <&3
             echo "$REPLY" >>"$aux"
        done
        read <&3
        echo "!$REPLY" >>"$aux"
    done
    rm -f "$matches2"
    mv -f "$aux" "$2"
    
    

    (píšu to z hlavy a nemám čas to zkoušet, takže tam asi budou nějaké chybičky)

    tomes.io avatar 13.8.2012 21:23 tomes.io | skóre: 12 | blog: tomesh
    Rozbalit Rozbalit vše Re: Automaticke porovnani a oznaceni odlisnosti v txt souboru
    No nakonec to slo vyresit bez lomitek:
    sed -i "s#$line#!$line#g" "$input1" "$input2"
    A zda se, ze to dela co potrebuju.
    14.8.2012 00:13 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: Automaticke porovnani a oznaceni odlisnosti v txt souboru
    Jen dokud tam někde nebude křížek.
    14.8.2012 00:19 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: Automaticke porovnani a oznaceni odlisnosti v txt souboru

    …nebo kterýkoli znak nebo kombinace znaků, které mají v regulárních výrazech speciální význam. A samozřejmě to bude matchovat i podřetězce.

    Gratuluji, podařilo se vám úspěšně ignorovat všechno, co jsem napsal ve svém příspěvku. Hlavně že jste si to označil jako řešení…

    tomes.io avatar 14.8.2012 13:46 tomes.io | skóre: 12 | blog: tomesh
    Rozbalit Rozbalit vše Re: Automaticke porovnani a oznaceni odlisnosti v txt souboru
    Tam budou jen normalni ceske vety uzavrene vyse zminenymi tagy. A prave ty tagy, resp. backslash delaly problemy. Krizky ani jine regularnevyrazove tam nebudou...

    ja dekuji za pomoc, ale moje reseni resi co ja potrebuji. nemusim osetrovat uplne vsechny pripady a moznosti. Pokud Vam to vadi, muzu se odznacit a jako reseni oznacit Vas prispevek... ja jen rikam, ze co jsem chtel, to jsem dostal..
    tomes.io avatar 14.8.2012 13:55 tomes.io | skóre: 12 | blog: tomesh
    Rozbalit Rozbalit vše Re: Automaticke porovnani a oznaceni odlisnosti v txt souboru
    navic Vase reseni zavorek:
    sed -e "s/^${line//\//\\/}$/\!&/"
    nefunguje. Skript neudela nic, nic neoznaci.

    14.8.2012 14:06 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: Automaticke porovnani a oznaceni odlisnosti v txt souboru

    Mně to funguje:

    mike@unicorn:~> line=x/y
    mike@unicorn:~> sed -e "s/^${line//\//\\/}$/\!&/" <<EOT
    ax/yb
    x/y
    xy
    EOT                                                                             
    ax/yb                                                                           
    !x/y                                                                            
    xy                                                                              
    
    3.8.2012 23:12 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: Automaticke porovnani a oznaceni odlisnosti v txt souboru
    Mám nejasné tušení, že hledáte příkaz comm (ale pozor, funguje jen na seřazené soubory).
    3.8.2012 20:53 Kit
    Rozbalit Rozbalit vše Re: Automaticke porovnani a oznaceni odlisnosti v txt souboru
    Opět mám tušení, že tady někdo vynalézá kolo, když si může z garáže vytáhnout auto. Když nám prozradíš, k čemu to potřebuješ, tak ti možná poradíme nějaký verzovací systém, který tvůj problém vyřeší komplexně.
    tomes.io avatar 3.8.2012 23:56 tomes.io | skóre: 12 | blog: tomesh
    Rozbalit Rozbalit vše Re: Automaticke porovnani a oznaceni odlisnosti v txt souboru
    Ja to dostal zkratka jako zadani ukolu pro skolni laborator... Rozkaz znel jasne: musi to byt bash script (verzovaci system tedy nepomuze) na porovnani textu (nejlepe schopny zpracovavat vice nez dva soubory zaraz) ktery bude nejak oznacovat vety/radky, ktere se neshoduji (vsechny texty jsem si uz predtim jinym skriptem upravil tak, aby 1 radka = 1 veta.
    4.8.2012 00:11 Michal Kubeček | skóre: 71 | Luštěnice
    Rozbalit Rozbalit vše Re: Automaticke porovnani a oznaceni odlisnosti v txt souboru
    Aha, takže domácí úkol. :-(
    tomes.io avatar 4.8.2012 00:34 tomes.io | skóre: 12 | blog: tomesh
    Rozbalit Rozbalit vše Re: Automaticke porovnani a oznaceni odlisnosti v txt souboru
    Dobrovolny ukol, nikoliv klasicky domaci. Koneckoncu jsou prazdniny, jenom ja blbec se chci neco porad ucit a delat ;) Proc ten smajlik, je na tom neco spatneho? Psal jsem, ze chci nakopnout, ne aby to za me nekdo vyresil (to bych se toho s takovou asi moc nenaucil, i kdyz jedna z cest jak se neco naucit je pry cist programy po druhych :)
    8.8.2012 15:44 Michal Vyskočil | skóre: 60 | blog: miblog | Praha
    Rozbalit Rozbalit vše Re: Automaticke porovnani a oznaceni odlisnosti v txt souboru
    Psal jsem, ze chci nakopnout
    V tom případě použij oblíbený vyhledávač a zadej "bash mapfile" - ale raději si ověř, že v zadání bylo bash skript.
    When your hammer is C++, everything begins to look like a thumb.

    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.