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

    AlmaLinux OS byl vydán ve verzích 9.8 s kódovým jménem Olive Jaguar a 10.2 s kódovým jménem Lavender Lion. Podrobnosti v poznámkách k vydání (9.8 a 10.2). Opraveny byly zranitelnosti Copy Fail (CVE-2026-31431), Dirty FRAG, Fragnesia (CVE-2026-46300), nginx Rift (CVE-2026-42945) a SSH Keysign Pwn (CVE-2026-46333).

    Ladislav Hagara | Komentářů: 0
    včera 15:22 | IT novinky

    Seznam.cz vykázal za rok 2025 tržby v celkové hodnotě 6,454 miliardy korun. Oproti roku 2024 nárůst o 3,68 %. Zisk před zdaněním oproti předcházejícímu roku poklesl, a to o 11,21 % na 1,330 miliardy korun. Vlastní velké jazykové modely SeLLMa najdou dnes uživatelé téměř na všech seznamáckých službách. Na všechny obsahové služby byla zavedena technologie text-to-speech, díky níž si mohou uživatelé přehrát články v audio verzi namluvené

    … více »
    Ladislav Hagara | Komentářů: 1
    včera 13:22 | IT novinky

    Vláda představila strategické digitalizační projekty. Roadmapa zahrnuje celkem 55 projektů napříč státní správou, z toho 22 prioritních projektů vycházejících přímo z programového prohlášení vlády a 33 projektů založených na platné legislativě. Portfolio pokrývá oblasti financí, zdravotnictví, digitální identity, dat, registrů, dopravy, krizového řízení, sociálních agend i kybernetické bezpečnosti.

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

    Vyjádřeni Software Freedom Conservancy (SFC) k porušování licence AGPLv3 společností Bambu Lab v jejich softwaru Bambu Studio pro 3D tisk. Bambu Studio vychází z PrusaSliceru. Ten zase z Slic3ru. Spuštěn byl projekt baltobu, který kombinuje několik strategií pro řešení problému. SFC zastřeší vývoj svobodné náhrady proprietární knihovny libbambu_networking pomocí reverzního inženýrství a reimplementace, forku OrcaSliceru pro Bambu Lab tiskárny od Paweła Jarczaka a forku celého Bambu Studia pod názvem Viscose.

    Ladislav Hagara | Komentářů: 3
    25.5. 22:44 | Nová verze

    Správce souborů GNOME Commander (Wikipedie) byl přepsán do Rustu a vydán v nové verzi 2.0.0.

    Ladislav Hagara | Komentářů: 1
    25.5. 19:44 | Nová verze

    Sway (Wikipedie), dlaždicový (tiling) správce oken pro Wayland kompatibilní s i3, byl vydán ve verzi 1.12. Do vývoje se zapojilo 50 vývojářů. Přehled novinek na GitHubu. Sway 1.12 závisí na wlroots 0.20.0.

    Ladislav Hagara | Komentářů: 0
    25.5. 16:33 | IT novinky

    Papež Lev XIV. ve své první encyklice Magnifica Humanitas (Skvělé lidství), která se věnuje umělé inteligenci (AI), varoval před dezinformacemi, které AI manipulací s obsahem vytváří. Moc mají podle něj sociální sítě ovládané hrstkou soukromníků. Upozornil také roli digitálních platforem v obchodování s lidmi, které podle něj musí být uznáno jako současná forma otroctví. Papež se také poprvé omluvil za roli, kterou Vatikán sehrál při legitimizaci otroctví, a za to, že jej po staletí neodsoudil.

    Ladislav Hagara | Komentářů: 0
    25.5. 16:11 | IT novinky

    Český telekomunikační úřad zveřejnil Výroční zprávu za rok 2025 (pdf), která shrnuje jeho hlavní aktivity v oblasti regulace elektronických komunikací, poštovních služeb, digitálních služeb a přípravy na dohled nad umělou inteligencí. Součástí zprávy jsou také data o vývoji trhu, včetně pokračujícího růstu spotřeby mobilních dat a rozšiřování sítí nové generace. Celkový objem přenesených mobilních dat dosáhl v roce 2025 přibližně

    … více »
    Ladislav Hagara | Komentářů: 0
    25.5. 16:00 | Nová verze

    Tým sdružení CZ.NIC vyvíjející routovacího daemona BIRD oznámil vydání nových verzí 3.3.0 a 2.19.0. Ty přinášejí podporu pro EVPN/VXLAN a automatizaci BGP na základě router advertisementů. Více informací je k dispozici v archivu uživatelského mailing-listu.

    VSladek | Komentářů: 0
    24.5. 04:33 | Nová verze

    Open source software pro úpravu digitálních fotografií LightZone (Wikipedie) byl vydán v nové verzi 5.0.0. LightZone je dnes k dispozici pod licencí BSD. Původně se jednalo o proprietární software vyvíjený společností Light Crafts. Ta v prosinci 2012 souhlasila s uvolněním zdrojových kódů jako open source [Wayback Machine].

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (12%)
     (8%)
     (2%)
     (14%)
     (31%)
     (4%)
     (7%)
     (3%)
     (16%)
     (26%)
    Celkem 1723 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník

    Dotaz: multiline grep

    30.4.2008 14:36 Terka | skóre: 13
    multiline grep
    Přečteno: 752×
    Mejme file kde zaznamy zacinaji "2008-" a jsou viceradkove. Chtela bych na nej provest grep tak aby mi zobrazil ne radky, ale zaznamy. Napsala jsem neco v Perlu, ale myslim, ze by to slo lepe. Muzete mi poradit?
    re="4718|4717";
    #main ######################################################
    $/=undef;
    
    
    while ($file=(<>)) # cteni z prikaz radky 
    {
    $a="\n".$file; #kvuli split \n2008
    chop ($a);  #kvuli print "$pole[$i]\n"; - zbavim se posledniho znaku enter
    @pole=split (/\n2008/,$a) ;
    $delka_pole=@pole;
    
    $i=1;
    while ($delka_pole > $i)
    {
        if ($pole[$i]=~/$re/)
        {
        $pridej ="2008" ;
        $pridej =$pridej.$pole[$i]."\n";
        $" = "";             #"########################### ok
        push (@vystup, $pridej);
        }
        $i++ ;
    }
    }
    

    Odpovědi

    30.4.2008 16:00 rastos | skóre: 63 | blog: rastos
    Rozbalit Rozbalit vše Re: multiline grep
    Je počet riadkov v zázname fixný? Ak áno, tak "grep -A".
    30.4.2008 16:37 Terka | skóre: 13
    Rozbalit Rozbalit vše Re: multiline grep
    neni, grep -A -B znam
    30.4.2008 16:41 Jan Šimák | skóre: 37 | Hradec Králové
    Rozbalit Rozbalit vše Re: multiline grep
    Přesně jsem nepochopil tvůj dotaz :-( ale pokud ti jde o počet úspěchů nalezení řetězce, tak by to šlo takto:
    chomp (my @var = STDIN>);
    my $times = grep (/se/m, @var);
    print "$times\n";
    30.4.2008 16:51 Terka | skóre: 13
    Rozbalit Rozbalit vše Re: multiline grep
    jde o grep ne na radky, ale na zaznamy. cili oddelovac neni \n ale ^2008.
    30.4.2008 20:01 ams
    Rozbalit Rozbalit vše Re: multiline grep
    perl -0777 -e 'print map "2008$_", grep /4718|4717/, split/\n2008/, <>' soubor_s_daty.dat
    
    30.4.2008 20:03 ams
    Rozbalit Rozbalit vše Re: multiline grep
    Pisu rychleji nez premyslim :). Toto bude lepsi:
    perl -0777 -e 'print grep /4718|4717/, split/\n(?=2008)/, <>' soubor_s_daty.dat
    
    30.4.2008 20:10 ams
    Rozbalit Rozbalit vše Re: multiline grep
    A jeste poznamka - kdybyste chtela nejakym zpusobem oznacit hranice zaznamu, pak je nejlepsi pouzit $,. Treba dat $,="\n####\n"; pred ten print.
    1.5.2008 11:23 Terka | skóre: 13
    Rozbalit Rozbalit vše Re: multiline grep
    diky za odpoved, mohla bych Vas poprosit jeste o komentar? S Perlem zacinam, tudiz nechapu jak Vas program pracuje. T.
    1.5.2008 11:59 Terka | skóre: 13
    Rozbalit Rozbalit vše Re: multiline grep
    me to za kazdym zaznamem tisklo \n, vam ho to netiskne.
    1.5.2008 12:59 Terka | skóre: 13
    Rozbalit Rozbalit vše Re: multiline grep
    uz mi to tiskne = moje blbost $,
    1.5.2008 13:09 Terka | skóre: 13
    Rozbalit Rozbalit vše Re: multiline grep
    tak to pomalu chapu
    -0777 nacte data jako jeden zaznam
    -e skript je v radce
    (?=2008) si zapamatuje 2008 a do pole to da vcetne toho 2008 (nezahodi tuto cast oddelovace)
    nechapu proc: 
    1. jsou carky mezi prikazy (jde o oddelovac vice prikazu na radce?)
    2. proc je poradi prikazu 1.print 2.split 3.<>
    diky!
    
    1.5.2008 13:17 Terka | skóre: 13
    Rozbalit Rozbalit vše Re: multiline grep
    muzete mi nekdo vysvetlit nasledujici:
    time cat soubor|perl -0777 -e '$,="\n", print grep /40030/, split/\n(?=2008)/, <>'
    real    0m1.137s
    user    0m0.760s
    sys     0m0.510s
    
    time cat soubor|perl -0777 -e 'print grep /40030/, split/(?=\n2008)/, <>' 
    real    0m8.116s
    user    0m7.800s
    sys     0m0.410s
    
    2.5.2008 12:04 ams
    Rozbalit Rozbalit vše Re: multiline grep
    Opravdu zvlastni chovani. Provedla jste mereni casu vicekrat u obou verzi?

    Co se tyce kodu, tak po $,="\n" bych radeji pouzil strednik misto carky i kdyz v tomto pripade je to celkem jedno. Carka obvykle neoddeluje prikazy (na to pouzivate strednik), ale zaznamy v seznamu anebo argumenty prikazu. Tento kod funguje takto:

    1) $,="\n"; Vkladame \n mezi jednotlive polozky v print. Napr., print("a","b","c"); ted vytiskne "a\nb\nc".

    2) Kdyz pridame zavorky, pak prikaz vypada nasledovne:
    print(grep(/40030/, split(/(?=\n2008)/, <>)))
    
    Takze to neni posloupnost prikazu, ale jsou to vlozene prikazy. Operator <> nacte cely soubor (protoze mame $/=undef v dusledku -0777). Provadime split na zaklade regexpu /(?=\n2008)/. Kdybychom pouzili jako oddelovac poli jenom /\n2008/, pak ztratili bychom tuto cast zaznamu (prave proto v mem prvnim reseni je map "2008$_", ktere vraci tuto cast zpatky). Kdyz pouzijeme look-ahead assertion (?=\n2008), pak vlastne provadime split v kazdem bode retezce, za kterym nasleduje \n2008, ale \n2008 neni brano jako soucast oddelovace poli. Vysledek splitu je seznam zaznamu, ktery je predavany jako druhy argument grepu. grep prochazi vsechny zaznamy tohoto seznamu a hleda jenom vyhovujici regexpu /40030/. Funguje nejak takto:
    for $_ (seznam_zaznamu_ktery_vygeneroval_split) {
       if ( $_ =~ /40030/ ) {
           nechame_tento_zaznam_ve_vysledku;
       } else {
           zahodime_tento_zaznam;
       }
    }
    
    Nakonec, print vytiskne vsechny nalezene zaznamy a vlozi mezi ne $, (v nasem pripade prazdny radek).
    2.5.2008 12:11 ams
    Rozbalit Rozbalit vše Re: multiline grep
    Mozna bude jednodussi si to zapsat jako nekolik prikazu:
    $, = "\n";
    $soubor = <>;
    @vsechny_zaznamy = split(/(?=\n2008)/, $soubor);
    @jenom_obsahujici_regexp = grep(/40030/, @vsechny_zaznamy);
    print @jenom_obsahujici_regexp;
    
    2.5.2008 12:26 Terka | skóre: 13
    Rozbalit Rozbalit vše Re: multiline grep
    ad 0) to mereni casu jsem delala nekolikrat.
    ad 1) ted je mi to jasne - vlozene prikazy - proto carka a proto to poradi.
    nakonec jsem tam jeste pridala sort (jako v mem puvodnim skriptu)
    casove je to +- stejne (muj puvodni vs vas)
    
    perl -0777 -e 'print sort grep /neco/, split/^(?=2008)/m, <>'
    velike diky za vysvetleni!
    
    2.5.2008 12:06 ams
    Rozbalit Rozbalit vše Re: multiline grep
    Mimochodem, misto cat soubor | perl -0777 -e '...' je lepsi pouzit perl -0777 -e '...' soubor
    2.5.2008 12:19 Terka | skóre: 13
    Rozbalit Rozbalit vše Re: multiline grep
    jasne. vim ze to je zacatecnicka chyba. delam to casto, lip se mi to cte.
    27.5.2008 07:33 jsk | skóre: 10
    Rozbalit Rozbalit vše Re: multiline grep

    Dobrý den,

    obdobný problém řeším tak, že pomocí tr -d '\r\n' (pro dos) spojím vše do jednoho řádku a následně sed-em rozřežu, na např. pro grep, použitelné řádky, tj. z mého pohledu standardně/typově začínající nebo končící. Pokud mi pošlete vzorek s konkrétním popisem požadavku, mohu se na to zkusit podívat.

    jsk
    27.5.2008 13:52 Yokotashi
    Rozbalit Rozbalit vše Re: multiline grep
    Predpokladam, ze soubor nemuze obsahovat nejaky znak (nebo muze jenom v komentari, kde se da snadno odstranit bez jeho poskozeni). Dejme tomu, ze ten znak je # (lze pouzit jakykoliv).

    cat file|sed 's/^2008/#/'|tr '\n#' '#\n'|grep 'treba konec tretiho#a zacatek ctvrteho radku zaznamu'|tr '\n#' '#\n'| sed 's/#/2008/g'

    Neni to moc hezke, ale funguje to spolehlive.
    27.5.2008 17:57 ams
    Rozbalit Rozbalit vše Re: multiline grep
    Napad je dobry, ale v tomto provedeni nefunguje uplne tak jak je treba. U prvniho nalezeneho zaznamu bude chybet 2008 a naopak za poslednim zaznamem bude 2008 navic. V textovych souborech zpravidla chybi znak s ASCII-kodem 0, proto muzeme pouzit sed 's/^2008/\x002008/' soubor_s_daty.dat | grep -z 'co_hledame' | tr -d '\0', ale i tak je to 4-krat pomalejsi nez reseni v Perlu.
    27.5.2008 18:04 ams
    Rozbalit Rozbalit vše Re: multiline grep
    Zase pisu rychleji nez premyslim :). Takhle to vypada lip (i kdyz funguje naproste stejne):
    sed 's/^2008/\x00&/' soubor_s_daty.dat | grep -z 'co_hledame' | tr -d '\0'

    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.