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

    Na čem pracují vývojáři webového prohlížeče Ladybird (GitHub)? Byl publikován přehled vývoje za prosinec 2025 a leden 2026 (YouTube). Zajímavé, že i v roce 2026 celou řadu problémů vyřeší nastavení řetězce User-Agent.

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

    Bylo rozhodnuto, že Linux From Scratch (LFS) končí s podporou System V init. Nové verze knih s návody na instalaci vlastního linuxového systému ze zdrojových kódů už budou pouze se systemd.

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

    Byla vydána nová verze 2026.1.0 "Like a Version" svobodného softwaru ScummVM (Wikipedie) umožňujícího bezproblémový běh mnoha klasických adventur na zařízeních, pro které nebyly nikdy určeny. Přehled novinek v poznámkách k vydání a na GitHubu. Změněno bylo číslování verzí. Předchozí verze byla 2.9.1.

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

    Internetový prohlížeč Firefox bude mít nové ovládací prvky pro umělou inteligenci, které umožní uživatelům vypnout vestavěné AI funkce přímo v nastavení prohlížeče. Jednotlivě půjde vypnout nebo zapnout automatické překlady stránek, generovaní popisného textu k obrázkům v otevřených PDF dokumentech, samoorganizaci tabů do skupin, náhledy odkazů s krátkým shrnutím a boční panel s chatbotem. Tyto možnosti v nastavení prohlížeče

    … více »
    NUKE GAZA! 🎆 | Komentářů: 1
    včera 14:44 | IT novinky

    Desktopové prostředí KDE Plasma 6.6, která je právě ve fázi beta, nahrazuje stávající SDDM novým Plasma Login Managerem, který je ale pevně navázán na systemd. Plasma Login Manager využívá systemd-logind a další součásti systemd, které nejsou dostupné v operačních systémech bez systemd, jako je například FreeBSD, případně jsou linuxové distribuce Gentoo, Void Linux anebo Alpine Linux. Pro uživatele zatím stále ještě existuje možnost používat SDDM.

    NUKE GAZA! 🎆 | Komentářů: 3
    včera 14:33 | Komunita

    Na webu komunitního setkání CSNOG 2026 jsou dostupné prezentace v PDF, jejich videozáznamy a fotografie z lednové akce ve Zlíně. CSNOG 2026 se zúčastnilo téměř 300 zájemců o vystoupení věnovaných správě sítí, legislativním a regulačním tématům nebo projektům z akademické sféry. Letos byly prezentace rozdělené do dvou treků, ve kterých se představilo 35 přednášejících. Setkání komunity CSNOG organizují společně sdružení CESNET, CZ.NIC a NIX.CZ.

    VSladek | Komentářů: 0
    včera 11:33 | IT novinky

    Americká vesmírná společnost SpaceX miliardáře Elona Muska koupila další Muskovu firmu xAI, která se zabývá vývojem umělé inteligence (AI). Informovala o tom na svém účtu na síti 𝕏. Musk tímto krokem propojí několik ze svých služeb, včetně chatbota s prvky umělé inteligence Grok, sociální sítě 𝕏 či satelitního internetového systému Starlink. Tržní hodnota společnosti SpaceX dosahuje jednoho bilionu dolarů (20,6 bilionu Kč), hodnota xAI pak činí 250 miliard dolarů.

    Ladislav Hagara | Komentářů: 3
    2.2. 23:22 | Bezpečnostní upozornění

    Byl odhalen supply chain attack na Notepad++: útočníci kompromitovali hosting Notepad++ a vybrané dotazy na aktualizace přesměrovávali na servery pod jejich kontrolou. Doporučuje se stáhnout instalátor a přeinstalovat.

    a1bert | Komentářů: 6
    2.2. 13:22 | Zajímavý projekt

    Francouzská veřejná správa má v rámci vládní iniciativy LaSuite Numérique ('Digitální sada') v plánu od roku 2027 přestat používat Microsoft Teams a Zoom a přejít na videokonferenční platformu Visio, hostovanou na vlastním hardwaru. Konkrétně se jedná o instance iniciativou vyvíjeného open-source nástroje LaSuite Meet, jehož centrální komponentou je LiveKit. Visio nebude dostupné pro veřejnost, nicméně LaSuite Meet je k dispozici pod licencí MIT.

    NUKE GAZA! 🎆 | Komentářů: 5
    2.2. 12:11 | IT novinky

    Eben Upton oznámil další zdražení počítačů Raspberry Pi: 2GB verze o 10 dolarů, 4GB verze o 15 dolarů, 8GB verze o 30 dolarů a 16GB verze o 60 dolarů. Kvůli růstu cen pamětí. Po dvou měsících od předchozího zdražení.

    Ladislav Hagara | Komentářů: 18
    Které desktopové prostředí na Linuxu používáte?
     (18%)
     (6%)
     (0%)
     (10%)
     (25%)
     (3%)
     (5%)
     (2%)
     (12%)
     (30%)
    Celkem 746 hlasů
     Komentářů: 25, poslední včera 19:50
    Rozcestník

    Dotaz: perl - pocet vyskytov retazca v texte

    13.3.2006 12:14 hrobar | skóre: 13
    perl - pocet vyskytov retazca v texte
    Přečteno: 239×
    Trocha som hral v perle s regularnymi vyrazmi a skusal som naprogramovat skriptik, ktory pocita pocet vyskytov retazca v texte. Skript vyzera takto:
    #!/usr/bin/perl -w                                                              
    use strict;                                                                     
                                                                                    
    open(FAJL,$ARGV[0]);                                                            
    my @lines = < FAJL >                                                             
    close(FAJL);                                                                    
                                                                                    
    my $i;                                                                          
    my $vyskyt=0;                                                                   
                                                                                    
    for ( $i=0; $i<(scalar @lines)-1; $i++ ) {                                      
                                                                                    
    $vyskyt += ($lines[$i] =~ tr/msgstr/msgstr/);                                   
                                                                                                                                                                    
    }                                                                               
                                                                                    
    print $vyskyt."\n"; 
    Ako vstup je pouzity po subor pre lokalizaciu isteho programu. Subor ma 3265 riadkov. Retazec msgstr sa vyskytuje na riadku maximalne jedenkrat, navyse sa nevyskytuje na kazdom riadku a v pocte riadkov su zahrnute aj prazdne riadky. Kazdopadne pocet msgstr nema sancu prekrocit hranicu 3265 vyskytov. Pocet vyskytov by sa mal pohybovat niekde v rozpati 600-700 vyskytov. Avsak po spusteni skriptiku mi to hodi cislo 20850 vyskytov. Cim je to sposobene?

    Odpovědi

    13.3.2006 12:31 michich
    Rozbalit Rozbalit vše Re: perl - pocet vyskytov retazca v texte
    Protoze tim ve skutecnosti pocitas, kolikrat se v textu vyskytuji pismenka m,s,g,t,r.
    13.3.2006 12:33 michich
    Rozbalit Rozbalit vše Re: perl - pocet vyskytov retazca v texte
    Zmen to na: $vyskyt += ($lines[$i] =~ /msgstr/); a melo by to fungovat.
    13.3.2006 12:57 hrobar | skóre: 13
    Rozbalit Rozbalit vše Re: perl - pocet vyskytov retazca v texte
    Tiez som mal pocit ze sa 'tr' na retazce neda aplikovat. Ide to aj nahradou 's' za 'tr' ale to tvoje riesenie je elegantnejsie. btw. ked regularnemu vyrazu neudam o co ide (s,tr,m) tak sa automaticky pocita s tym, ze ide o pattern matching teda 'm'? Inak povedane =~ /msgstr/ je to iste ako =~ m/msgstr/?
    13.3.2006 14:30 Hynek (Pichi) Vychodil | skóre: 43 | blog: Pichi | Brno
    Rozbalit Rozbalit vše Re: perl - pocet vyskytov retazca v texte
    1. RTFM
    2. RTFM
    3. RTFM
    Tak dobrá
    1. tr není s ani m
    2. Když hledaný řeťezec nemůže přesahovat konec řádku, tak jen naprostý programátorský někňuba bude načítat do paměti celý soubor a i tak by to programátor, jen trochu zběhlý v perlu, udělal mnohem elegantněji takto:
      #!/usr/bin/env perl
      use warnings;
      use strict;
      undef $/;
      my $vyskyt=0;
      $_ = <>;
      $vyskyt++ while m/msgstr/g;
      print $vyskyt,"\n";
      
      Trošku zkušenější třeba takto
      #!/usr/bin/env perl
      use warnings;
      use strict;
      undef $/;
      print scalar @{[<> =~ m/msgstr/g]}, "\n";
    3. Jenže protože takový programátor nebude trouba a nebude načítat celý soubor do paměti, tak to udělá třeba takto:
      #!/usr/bin/env perl
      use warnings;
      use strict;
      my $vyskyt = 0;
      $vyskyt += @{[m/msgstr/g]} while <> ;
      print $vyskyt,"\n";
      
      Nebo dokonce jako onliner
      perl -ne '$vyskyt += @{[m/msgstr/g]}; END{print $vyskyt,"\n"}'
    XML je zbytečný, pomalý, nešikovný balast, znovu vynalézané kolo a ještě ke všemu šišaté, těžké a kýčovitě pomalované.
    13.3.2006 15:22 hrobar | skóre: 13
    Rozbalit Rozbalit vše Re: perl - pocet vyskytov retazca v texte
    1. Ja som ani netvrdil ze tr=s=m. tr=translation, s=substitution, m=pattern matching.

    2. Nie vsetci su taky super spica neomylne dokonaly programatori ako ty.

    3. Diky za riesenia. Konecne som pochopil preco je perl "chlpaty".

    4. Nebolo by od veci keby si popri tom urazani odpovedal na otazku, ktoru som polozil a sice je =~ /msgstr/ to iste ako =~ m/msgstr/? Odpoviem si sam, je.
    13.3.2006 16:42 barney
    Rozbalit Rozbalit vše Re: perl - pocet vyskytov retazca v texte
    to imho nebolo urážanie :-)

    btw, ešte môžeš skúsiť nasledovné:

    $vyskyt = grep { m/msgstr/ } <>;
    
    # alebo
    
    print scalar grep { m/msgstr/ } <>;
    

    to platí pre jeden riadok = jeden výskyt. Inak možno použiť i nasledovnú konštrukciu:
    $/ = 'msgstr';
    1 while <>;
    print $., "\n";
    
    13.3.2006 18:01 Hynek (Pichi) Vychodil | skóre: 43 | blog: Pichi | Brno
    Rozbalit Rozbalit vše Re: perl - pocet vyskytov retazca v texte
    Inak možno použiť i nasledovnú konštrukciu:
    $/ = 'msgstr';
    1 while <>;
    print $., "\n";
    
    Máš bod :-) Ale správně to má být
    $/ = 'msgstr';
    1 while <>;
    print $. - 1, "\n";
    
    XML je zbytečný, pomalý, nešikovný balast, znovu vynalézané kolo a ještě ke všemu šišaté, těžké a kýčovitě pomalované.
    13.3.2006 18:15 barney
    Rozbalit Rozbalit vše Re: perl - pocet vyskytov retazca v texte
    hmm, máš pravdu :-)

    TIMTOWDI ...
    undef $/;
    print -1 + scalar split (/msgstr/, <>), "\n";
    
    14.3.2006 08:58 Hynek (Pichi) Vychodil | skóre: 43 | blog: Pichi | Brno
    Rozbalit Rozbalit vše Re: perl - pocet vyskytov retazca v texte
    Hezké, akorat to scalar je tam zbytečné, protože + to přepne do skalárního kontextu. Použít split mě nenapadlo a přitom je to tak hezké :-) Jako one liner a bez načítání všeho naráz to pak může být třeba
    perl -ne '$a+=-1+split/msgstr/; END{print "$a\n"}'
    Ale když už jsme u toho splitu, tak hezčí by bylo
    perl -Fmsgstr -ane '$a+=-1+@F; END{print "$a\n"}'
    XML je zbytečný, pomalý, nešikovný balast, znovu vynalézané kolo a ještě ke všemu šišaté, těžké a kýčovitě pomalované.
    14.3.2006 09:00 Hynek (Pichi) Vychodil | skóre: 43 | blog: Pichi | Brno
    Rozbalit Rozbalit vše Re: perl - pocet vyskytov retazca v texte
    Můžem ještě ušetřit znak
    perl -Fmsgstr -ane'$a+=@F-1;END{print "$a\n"}'
    XML je zbytečný, pomalý, nešikovný balast, znovu vynalézané kolo a ještě ke všemu šišaté, těžké a kýčovitě pomalované.
    14.3.2006 09:01 Hynek (Pichi) Vychodil | skóre: 43 | blog: Pichi | Brno
    Rozbalit Rozbalit vše Re: perl - pocet vyskytov retazca v texte
    A ještě jeden :-)
    perl -Fmsgstr -ane'$a+=$#F;END{print "$a\n"}'
    XML je zbytečný, pomalý, nešikovný balast, znovu vynalézané kolo a ještě ke všemu šišaté, těžké a kýčovitě pomalované.
    14.3.2006 09:10 Hynek (Pichi) Vychodil | skóre: 43 | blog: Pichi | Brno
    Rozbalit Rozbalit vše Re: perl - pocet vyskytov retazca v texte
    Pro srovnání neoptimální načtení celého souboru
    perl -e'undef$/;print-1+split("msgstr",<>),"\n"'
    a nejkratší varianta se čtením po řádcích
    perl -Fmsgstr -ane'$a+=$#F;END{print"$a\n"}'
    XML je zbytečný, pomalý, nešikovný balast, znovu vynalézané kolo a ještě ke všemu šišaté, těžké a kýčovitě pomalované.
    14.3.2006 09:20 Hynek (Pichi) Vychodil | skóre: 43 | blog: Pichi | Brno
    Rozbalit Rozbalit vše Re: perl - pocet vyskytov retazca v texte
    Jen pro pořádek aby byla sbírka kompletní
    perl -ne'BEGIN{$/="msgstr"}END{print$.-1,"\n"}'
    XML je zbytečný, pomalý, nešikovný balast, znovu vynalézané kolo a ještě ke všemu šišaté, těžké a kýčovitě pomalované.
    14.3.2006 09:32 barney
    Rozbalit Rozbalit vše Re: perl - pocet vyskytov retazca v texte
    lol :-)
    jeden telefonát počas písania odpovede :-(((
    14.3.2006 09:37 barney
    Rozbalit Rozbalit vše Re: perl - pocet vyskytov retazca v texte
    ok, ešte jedno vylepšenie ...
    perl -ne'BEGIN{$/=shift}END{print$.-1,"\n"}' msgstr
    
    rozdiel oproti nižšie spomenutému grep-u je v počítaní výskytov a nie riadkov s výskytom
    14.3.2006 10:06 mrak | skóre: 12 | Olomouc
    Rozbalit Rozbalit vše Re: perl - pocet vyskytov retazca v texte
    myslel sem ze perl trochu umim ale pichi je demon!
    no zrejmne lepsi oddil :)
    14.3.2006 09:30 barney
    Rozbalit Rozbalit vše Re: perl - pocet vyskytov retazca v texte
    :-))
    dúfam, že sme nikoho od perlu neodradili :-))

    v porovnani so split, resp s $/ má najkratší variant nevýhodu v tom, že hľadaný reťazec nemôže obsahovať new-line ... takže o tri znaky viac

    perl -ne'BEGIN{$/="msgstr"}END{print$.-1,"\n"}' 
    
    14.3.2006 09:27 Hynek (Pichi) Vychodil | skóre: 43 | blog: Pichi | Brno
    Rozbalit Rozbalit vše Re: perl - pocet vyskytov retazca v texte
    Jo jentak mimochodem, když chci spočítat počet řádků obsahujících určitý řetězec, tak úplně nejlepší je
    grep -c msgstr
    XML je zbytečný, pomalý, nešikovný balast, znovu vynalézané kolo a ještě ke všemu šišaté, těžké a kýčovitě pomalované.
    14.3.2006 12:12 hrobar | skóre: 13
    Rozbalit Rozbalit vše Re: perl - pocet vyskytov retazca v texte
    Ono to bolo cele trochu inak. Niekde na webe som narazil na nasledovnu konstrukciu $count +=($sentence =~ tr/*/*/). Zhodou okolnosti som pracoval na preklade isteho softu a zacalo mi v hlave vrtat(zo zvedavosti) ako by sa dalo v perle realizovat spocitanie vyskytu vybraneho retazca v urcitom subore, vyuzitim zmienovanej konstrukcie. Neslo mi o to aby to bolo naj a ani o to aby som spocital pocet retazcov v preklade. Tie sa daju lahko spocitat cez msgfmt --statistics your.po a netreba ani nic programovat. Potom si sa objavil ty a prisiel so svojimi minimalistickymi rieseniami, coz je fajn aspon sa nieco priucim. S preliezania webu a citania programov mam vsak skusenost taku, ze riesenia tvojho druhu sa moc nepouzivaju. Preco? Stale vsak uplne nerozumiem ako perl tie znaky pocita. Moj odhad je taky, ze obsah zatvorky vyhodnoti ako boolean a ten potom vrati ako 1 alebo 0. A pretoze ked v '$sentence' najde '*' vrati true co je 1 je mozne tohoto faktu vyuzit napriklad na urcenie poctu znakov v retazci. Mam pravdu, alebo sa mylim?
    14.3.2006 13:04 Hynek (Pichi) Vychodil | skóre: 43 | blog: Pichi | Brno
    Rozbalit Rozbalit vše Re: perl - pocet vyskytov retazca v texte
    RTFM
           tr/SEARCHLIST/REPLACEMENTLIST/cds
           y/SEARCHLIST/REPLACEMENTLIST/cds
                   Transliterates all occurrences of the characters found in the
                   search list with the corresponding character in the replacement
                   list.  It returns the number of characters replaced or deleted.
                   If no string is specified via the =~ or !~ operator, the $_
                   string is transliterated.  (The string specified with =~ must
                   be a scalar variable, an array element, a hash element, or an
                   assignment to one of those, i.e., an lvalue.)
    
    XML je zbytečný, pomalý, nešikovný balast, znovu vynalézané kolo a ještě ke všemu šišaté, těžké a kýčovitě pomalované.
    14.3.2006 13:05 barney
    Rozbalit Rozbalit vše Re: perl - pocet vyskytov retazca v texte
    tr// vrati počet nahradených alebo zmazaných znakov. v tomto prípade koľko '*' sa nachádza v retazci.

    odpoveď na otázku "prečo" je jednoduchá ... drvivá vačšina programátorov sa zastaví pri prvom funkčnom riešení. A ako vidíš aj z tejto diskusie, riešenie iterovalo v niekoľkých krokoch. Nevraviac o tom, že tu sú vypísané asi všetky kroky, podľa toho, kto si kedy na akú vlastnosť spomenul :-)

    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.