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 14:00 | Zajímavý projekt

Byl spuštěn Humble Down Under Bundle. Za vlastní cenu lze koupit multiplatformní hry The Warlock of Firetop Mountain, Screencheat, Hand of Fate a Satellite Reign. Při nadprůměrné platbě (aktuálně 3,63 $) také Hacknet, Hacknet Labyrinths, Crawl a Hurtworld. Při platbě 12 $ a více lze získat navíc Armello.

Ladislav Hagara | Komentářů: 0
dnes 13:00 | Nová verze

Google Chrome 62 byl prohlášen za stabilní (YouTube). Nejnovější stabilní verze 62.0.3202.62 tohoto webového prohlížeče přináší řadu oprav a vylepšení. Vylepšeny byly také nástroje pro vývojáře (YouTube). Opraveno bylo 35 bezpečnostních chyb.

Ladislav Hagara | Komentářů: 1
dnes 11:00 | Zajímavý článek

Článek (en) na Mozilla.cz je věnován vykreslování stránek ve Firefoxu. V průběhu roku 2018 by se ve Firefoxu měl objevit WebRender, jenž by měl vykreslování stránek urychlit díky využití GPU.

Ladislav Hagara | Komentářů: 3
dnes 08:22 | Bezpečnostní upozornění

NÚKIB (Národní úřad pro kybernetickou a informační bezpečnost) informuje o zranitelnosti ROCA v procesu generování RSA klíčů, který se odehrává v softwarové knihovně implementované například v kryptografických čipových kartách, bezpečnostních tokenech a dalších hardwarových čipech vyrobených společností Infineon Technologies AG. Zranitelnost umožňuje praktický faktorizační útok, při kterém útočník dokáže vypočítat

… více »
Ladislav Hagara | Komentářů: 2
dnes 01:23 | Zajímavý software

Příspěvek na blogu otevřené certifikační autority Let's Encrypt informuje o začlenění podpory protokolu ACME (Automatic Certificate Management Environment) přímo do webového serveru Apache. Klienty ACME lze nahradit novým modulem Apache mod_md. Na vývoj tohoto modulu bylo uvolněno 70 tisíc dolarů z programu Mozilla Open Source Support (MOSS). K rozchození HTTPS na Apache stačí nově přidat do konfiguračního souboru řádek s ManagedDomain. Minutový videonávod na YouTube [reddit].

Ladislav Hagara | Komentářů: 1
včera 14:15 | Komunita

Daniel Stenberg, autor nástroje curl, na svém blogu oznámil, že obdržel letošní Polhemovu cenu, kterou uděluje Švédská inženýrská asociace za „technologickou inovaci nebo důvtipné řešení technického problému“.

marbu | Komentářů: 9
včera 13:40 | Pozvánky

Cílem Social Good Hackathonu, který se uskuteční 21. a 22. října v Brně, je vymyslet a zrealizovat projekty, které pomůžou zlepšit svět kolem nás. Je to unikátní příležitost, jak představit nejrůznější sociální projekty a zrealizovat je, propojit aktivní lidi, zástupce a zástupkyně nevládních organizací a lidi z prostředí IT a designu. Hackathon pořádá brněnská neziskovka Nesehnutí.

… více »
Barbora | Komentářů: 1
včera 00:44 | Pozvánky

V sobotu 21. října 2017 se na půdě Elektrotechnické fakulty ČVUT v Praze uskuteční RT-Summit – setkání vývojářů linuxového jádra a uživatelů jeho real-time verze označované jako preempt-rt.

… více »
Pavel Píša | Komentářů: 8
16.10. 23:44 | Bezpečnostní upozornění

V Linuxu byla nalezena bezpečnostní chyba CVE-2017-15265 zneužitelná k lokální eskalaci práv. Jedná se o chybu v části ALSA (Advanced Linux Sound Architecture).

Ladislav Hagara | Komentářů: 1
16.10. 22:44 | Komunita

Greg Kroah-Hartman informuje na svém blogu, že do zdrojových kódu linuxového jádra bylo přidáno (commit) prohlášení Linux Kernel Enforcement Statement. Zdrojové kódy Linuxu jsou k dispozici pod licencí GPL-2.0. Prohlášení přidává ustanovení z GPL-3.0. Cílem je chránit Linux před patentovými trolly, viz například problém s bývalým vedoucím týmu Netfilter Patrickem McHardym. Více v často kladených otázkách (FAQ).

Ladislav Hagara | Komentářů: 4
Jak se vás potenciálně dotkne trend odstraňování analogového audio konektoru typu 3,5mm jack z „chytrých telefonů“?
 (16%)
 (2%)
 (0%)
 (2%)
 (69%)
 (12%)
Celkem 51 hlasů
 Komentářů: 2, poslední dnes 18:09
    Rozcestník

    Dotaz: Filtr noveho radku

    2.4.2007 20:15 bizi | skóre: 8
    Filtr noveho radku
    Přečteno: 117×
    Dobry den, chtel bych se zeptat, jakym zpusobem je mozne odfiltrovat novy radek v souboru na radcich, na kterych se vyskytuje urcity vyraz. Priklad:
    text1
    text2
    text3
    klic_slovo
    text4
    text5
    ...
    Potreboval bych vysledek asi takto:
    text1
    text2
    text3
    klic_slovo text4
    text5
    ...
    Zkousel jsem to pomoci sedu, awk i grepu, ale k touzenemu vysledku jsem se bohuzel nedostal.. Honza.

    Odpovědi

    Fuky avatar 2.4.2007 21:30 Fuky | skóre: 52 | blog: 4u
    Rozbalit Rozbalit vše Re: Filtr noveho radku

    Dle UZITEČNÉ JEDNOŘÁDKOVÉ SKRIPTY PRO SED je řešení např. toto:
    cat file.txt |sed -e :a -e '/klic_slovo$/N; s/\n/ /; ta'

    2.4.2007 23:32 Jan Martinek | skóre: 43 | blog: johny | Brno
    Rozbalit Rozbalit vše Re: Filtr noveho radku
    Tady je taková malá interaktivní verze. Spusť tohle a zkus editovat text v levé části okna.
    Následující zdroják označ myší a prostředním tlačítkem zkopíruj do terminálu:
    python << EOF
    import gtk
    
    class TwoTexts:
        def __init__(self, buff, klic_slovo):
            self.klic_slovo = klic_slovo
    
            txtv1 = gtk.TextView()
            buff1 = txtv1.get_buffer()
            buff1.set_text(buff)
    
            sep = gtk.VSeparator()
    
            txtv2 = gtk.TextView()
            txtv2.set_editable(False)
            buff2 = txtv2.get_buffer()
    
            self.buffer_changed(buff1, buff2)
            buff1.connect('changed', self.buffer_changed, buff2)
    
            hbox = gtk.HBox(False, 0)
            hbox.pack_start(txtv1, True, True, 0)
            hbox.pack_start(sep, False, True, 0)
            hbox.pack_start(txtv2, True, True, 0)
            hbox.show_all()
    
            w = gtk.Window(gtk.WINDOW_TOPLEVEL)
            w.set_position(gtk.WIN_POS_CENTER)
            w.connect('destroy', gtk.main_quit)
            w.connect('delete_event', self.delete_event)
            w.add(hbox)
            w.show_all()
    
        def delete_event(self, widget, data = None):
            return False
    
        def buffer_changed(self, buff1, buff2):
            start, end = buff1.get_bounds()
            text = buff1.get_text(start, end)
            newtext = text.replace(self.klic_slovo + '\n',
                                   self.klic_slovo + ' ')
            buff2.set_text(newtext)
    
        def runapp(self):
            gtk.main()
    
    buff = '''text1
    text2
    text3
    klic_slovo
    text4
    text5'''
    
    twotexts = TwoTexts(buff, 'klic_slovo')
    twotexts.runapp()
    EOF
    
    3.4.2007 08:31 ajikdpoe | skóre: 23 | blog: dvh
    Rozbalit Rozbalit vše Re: Filtr noveho radku
    Hmm... docela peky rozdiel napisat sed "oneliner" a 30 riadkov pythonieho kodu... Ale toto je priklad jednoznacne na sed
    Fuky avatar 3.4.2007 10:05 Fuky | skóre: 52 | blog: 4u
    Rozbalit Rozbalit vše Re: Filtr noveho radku

    cat file.txt |python -c 'import re; import sys; print re.sub(r"(klic_slovo)\n", "\\1 ", sys.stdin.read())'

    Na malý soubor je celkem jedno co použijete, ale jakmile bude soubor stejně velký jako vaše RAM, tak jste na tomto příkladu v pythonu skončili (jasný šlo by to vyřešit, ale to by bylo proti Unixové filozofii, proč znovu vymýšlet kolo). Zkuste se podívat na top, když pracuje python a když sed. Všimněte si, že sed nežere žádnou paměť ;-) a v tom je jeho síla, je to starý dobrý Unixový nástroj. BTW: sort a další sofistikované nástroje jsou na tom stejně, je jim jedno kolik máte paměti a přece dokončí svojí činost ;-) Zkuste se podívat do /tmp při použití sort na velký soubor a uvidíte proč...

    3.4.2007 12:01 Jan Martinek | skóre: 43 | blog: johny | Brno
    Rozbalit Rozbalit vše Re: Filtr noveho radku
    Prosím, nepište v pythonu onelinery. Není k tomu důvod a špatně se to čte. Následující program zpracovává soubor po řádcích, takže paměť nesežere. Běží o 30% pomaleji než varianta v sedu.
    Netvrdím, že něco je lepší a něco horší - v tom už má stejně každý jasno. Řešení uvádím pro ty, kteří už v pythonu píšou a náhodou by řešili stejný problém.
    #!/usr/bin/env python
    import sys
    k1 = 'klic_slovo\n'
    k2 = 'klic_slovo '
    for line in sys.stdin:
        if line == k1: line = k2
        sys.stdout.write(line)
    
    Fuky avatar 3.4.2007 13:35 Fuky | skóre: 52 | blog: 4u
    Rozbalit Rozbalit vše Re: Filtr noveho radku

    Sorry, verze na jednom řádku byla jen pro rýpaly a jak jsem se to snažil nahečmat na jeden řádek, tak jsem udělal tu blbost, že jsem nejprve načetl komplet celý vstup do paměti což je moje chyba a ne Pythonu :-D

    Nechci tvrdit, že je něco lepší nebo horší, Python mám rád, jen si chci ujasnit na co je lepší se mu vyhnout. Na menší množství dat je bez diskuze pohodlnější po všech stránkách, pokud to není věc, která se jednou napíše přímo do příkazové řádky, již nikdy se nepoužuje a dotyčný zvládá sed, gawk atp.

    Myslím, že když chceš srovnávat rychlost, bylo by férové použít i v Pythonu regulární výrazy. Přeci jenom není to vždy takovéto jednoduché porovnávání.

    ~12x pomalejší:

    for line in sys.stdin:
      sys.stdout.write(re.sub(r"(klic_slovo)\n", "\\1 ", line))
    

    ~6x pomalejší:

    pattern1 = re.compile(r"klic_slovo\n")
    pattern2 = re.compile(r"(klic_slovo)\n")
      
    for line in sys.stdin:
      if (re.search(pattern1, line) == None):
        sys.stdout.write(line)
      else:
        sys.stdout.write(re.sub(pattern2, "\\1 ", line))
    

    Napadá Tě jak to v Pythonu ještě urychlit? Podmínka je samozřejmě zachovat možnost využití regulárních výrazů ;-)

    Jinak u sedu si můžeme v tomto případě odpustit skákání na značku a, pak je to ještě krapet (opravdu zanedbatelně) rychlejší:

    cat file.txt |sed '/klic_slovo$/N; s/\n/ /;'
    

    3.4.2007 18:13 Jan Martinek | skóre: 43 | blog: johny | Brno
    Rozbalit Rozbalit vše Re: Filtr noveho radku
    Myslím, že máme stejný pohled na věc.
    A co se týče těch regulárních výrazů, máš pravdu, jsou fakt pomalé. Zajímalo by mě, kde je úzké hrdlo, jestli to souvisí s pythonem jako takovým, jeho dynamičností, function call overheadem (jak se to safra řekne česky?), s algoritmem, který používá pro vyhodnocení nebo jestli je to vším dohromady.
    Srovnával jsem rychlost načítání souboru a tisk řádků v pythonu, perlu a sedu a rozdíly jsou celkem malé. Ale přidáním regulárních výrazů začne python výrazně zaostávat. Přitom soudě podle tohoto
    http://swtch.com/~rsc/regexp/regexp1.html
    By se od perlu moc lišit nemusel. Divné ...
    3.4.2007 22:27 Messa | skóre: 39 | blog: Messa
    Rozbalit Rozbalit vše Re: Filtr noveho radku
    Dalo by se to urychlit předkompilováním těch regulárních výrazů. Sice to tam máš, ale místo re.search(pattern1, line) je podle mých pokusů rychlejší pattern1.search (line).
    4.4.2007 00:18 Jan Martinek | skóre: 43 | blog: johny | Brno
    Rozbalit Rozbalit vše Re: Filtr noveho radku
    Tohle je to nejrychlejší, co dokážu vymyslet:
    #!/usr/bin/env python
    import sys, re
    
    def run():
        search = re.compile(r'(klic_slovo)\n').search
        write = sys.stdout.write
        for line in sys.stdin:
            s = search(line)
            if s: line = s.groups()[0] + ' '
            write(line)
    run()
    
    Ale je to pořád o cca 70% pomalejší než sed nebo perl.

    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.