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 18:44 | Komunita

    Od soboty do úterý probíhá v Hamburku konference 39C3 (Chaos Communication Congress) věnovaná také počítačové bezpečnosti nebo hardwaru. Program (jiná verze) slibuje řadu zajímavých přednášek. Streamy a záznamy budou k dispozici na media.ccc.de.

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

    Byl představen nový Xserver Phoenix, kompletně od nuly vyvíjený v programovacím jazyce Zig. Projekt Phoenix si klade za cíl být moderní alternativou k X.Org serveru.

    🇨🇽 | Komentářů: 2
    včera 13:11 | Nová verze

    XLibre Xserver byl 21. prosince vydán ve verzi 25.1.0, 'winter solstice release'. Od založení tohoto forku X.Org serveru se jedná o vůbec první novou minor verzi (inkrementovalo se to druhé číslo v číselném kódu verze).

    🇨🇽 | Komentářů: 0
    včera 03:33 | Nová verze

    Wayback byl vydán ve verzi 0.3. Wayback je "tak akorát Waylandu, aby fungoval Xwayland". Jedná se o kompatibilní vrstvu umožňující běh plnohodnotných X11 desktopových prostředí s využitím komponent z Waylandu. Cílem je nakonec nahradit klasický server X.Org, a tím snížit zátěž údržby aplikací X11.

    Ladislav Hagara | Komentářů: 0
    25.12. 14:44 | Nová verze

    Byla vydána verze 4.0.0 programovacího jazyka Ruby (Wikipedie). S Ruby Box a ZJIT. Ruby lze vyzkoušet na webové stránce TryRuby. U příležitosti 30. narozenin, první veřejná verze Ruby 0.95 byla oznámena 21. prosince 1995, proběhl redesign webových stránek.

    Ladislav Hagara | Komentářů: 0
    24.12. 02:11 | Komunita

    Všem čtenářkám a čtenářům AbcLinuxu krásné Vánoce.

    Ladislav Hagara | Komentářů: 29
    24.12. 02:00 | Nová verze

    Byla vydána nová verze 7.0 linuxové distribuce Parrot OS (Wikipedie). S kódovým názvem Echo. Jedná se o linuxovou distribuci založenou na Debianu a zaměřenou na penetrační testování, digitální forenzní analýzu, reverzní inženýrství, hacking, anonymitu nebo kryptografii. Přehled novinek v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    23.12. 18:33 | Nová verze

    Vývojáři postmarketOS vydali verzi 25.12 tohoto před osmi lety představeného operačního systému pro chytré telefony vycházejícího z optimalizovaného a nakonfigurovaného Alpine Linuxu s vlastními balíčky. Přehled novinek v příspěvku na blogu. Na výběr jsou 4 uživatelská rozhraní: GNOME Shell on Mobile, KDE Plasma Mobile, Phosh a Sxmo.

    Ladislav Hagara | Komentářů: 0
    23.12. 13:55 | Nová verze

    Byla vydána nová verze 0.41.0 multimediálního přehrávače mpv (Wikipedie) vycházejícího z přehrávačů MPlayer a mplayer2. Přehled novinek, změn a oprav na GitHubu. Požadován je FFmpeg 6.1 nebo novější a také libplacebo 6.338.2 nebo novější.

    Ladislav Hagara | Komentářů: 0
    23.12. 12:44 | Nová verze

    Byla vydána nová verze 5.5 (novinky) skriptovacího jazyka Lua (Wikipedie). Po pěti a půl letech od vydání verze 5.4.

    Ladislav Hagara | Komentářů: 0
    Kdo vám letos nadělí dárek?
     (36%)
     (2%)
     (15%)
     (2%)
     (2%)
     (2%)
     (15%)
     (16%)
     (11%)
    Celkem 112 hlasů
     Komentářů: 18, poslední 24.12. 15:29
    Rozcestník

    Dotaz: python skript na regularni vyrazy

    9.8.2007 15:04 jooke | skóre: 9 | Opava
    python skript na regularni vyrazy
    Přečteno: 578×
    Zdravim, pisu nasleduji skript, ktery si otevre log soubor a prohledava v nem vyskyt vyrazu ze seznamu vzor. Stavaji situace je, ze projde soubor na vyskyt prvniho vzoru a shodujici radky se vzorem zapise do noveho souboru, potom projde zase log soubor na vyskyt dalsiho vzoru a zapise do souboru kdyz je vzor v radku. Chci, aby prosel radek na jednou na vyskyt vsech vzoru, a kdyz se nejaky vzor shoduje s radkem, tak at ho zapise do souboru. Bohuzel si nevim rady jak to udelat :-(.

    Stavaji skript:
    me = open(error_log, 'w+')
    vzor = ["error", "warn","unexpected"]
            for i in range(len(vzor)):
                    regexp = vzor[i]
                    vzor_regexp = re.compile(regexp, re.IGNORECASE)
                    for line in file('cesta/k/logu'):
                            test = vzor_regexp.findall(line)
                            if test:
                                   me.write(line)
    me.close()
    

    Odpovědi

    9.8.2007 15:13 outsider
    Rozbalit Rozbalit vše Re: python skript na regularni vyrazy
    Vyprdnout se na python a pouzit fgrep ? ;-)
    9.8.2007 15:18 happy barney | skóre: 34 | blog: dont_worry_be_happy
    Rozbalit Rozbalit vše Re: python skript na regularni vyrazy
    chce viac slov, to je grep alebo egrep

    pre regulárne výrazy: Alternation

    9.8.2007 15:17 Jan Martinek | skóre: 43 | blog: johny | Brno
    Rozbalit Rozbalit vše Re: python skript na regularni vyrazy
    Mohl bys ukázat pár řádků z toho logu? Bylo by fajn, kdyby "error", "warn" a "unexpected" bylo v řádku na stále stejných pozicích. Nerad bych to dělal nějak hrubou silou.
    9.8.2007 15:19 happy barney | skóre: 34 | blog: dont_worry_be_happy
    Rozbalit Rozbalit vše Re: python skript na regularni vyrazy
    error|warn|unexpected, aká hrubá sila?
    9.8.2007 15:35 jooke | skóre: 9 | Opava
    Rozbalit Rozbalit vše Re: python skript na regularni vyrazy
    pozice muze byt jakakoliv...
    log je smed ruznych slov a chyb. Potrebuji to v Pythonu, skript dela i jine veci a kvuli rychlosti to chci mit cele v Pythonu.
    9.8.2007 15:45 Jan Martinek | skóre: 43 | blog: johny | Brno
    Rozbalit Rozbalit vše Re: python skript na regularni vyrazy
    Tak zkus tohle:
    #!/usr/bin/python
    import sys
    vzory = ["root", "/var", "10"]
    for line in file('/etc/passwd'):
        for vzor in vzory:
            if vzor in line:
                sys.stdout.write(line)
                break
    
    testoval jsem to na souboru s půlmiliónem řádků a je to o pár procent pomalejší než egrep.
    9.8.2007 16:05 jooke | skóre: 9 | Opava
    Rozbalit Rozbalit vše Re: python skript na regularni vyrazy
    To vypada slusne. Diky.
    Jeste bych, ale chtel at to neni case sensitive a jeste bych chtel mit seznam vzory2, ve kterem by byly slova, ktere nechci prohledavat.
    Pr.:
    Soubor obsahuje:
    error bla bla
    error neco neco bla bla
    ve vzoru bude treba = ["error"]
    a ve vzoru2 ["error neco"]
    tak prvni radek zapisu do souboru, protoze je tam vyraz error, ale druhy radek uz ne, protoze je tam slovni spojeni "error neco",
    ktere chci ignorovat.
    9.8.2007 16:33 Jan Martinek | skóre: 43 | blog: johny | Brno
    Rozbalit Rozbalit vše Re: python skript na regularni vyrazy
    Tak třeba takhle:
    #!/usr/bin/python
    import sys
    
    def jevzor(line, vzory):
        for vzor in vzory:
            if vzor in line:
                return True
        return False
    
    chci = ["root", "/var", "10"]
    nechci = ["nologin", "nfs"]
    
    for line in file('/etc/passwd'):
        low = line.lower()
        if jevzor(low, chci) and not jevzor(low, nechci):
            sys.stdout.write(line)
    
    Ale nevím, jak to bude rychlé. S ničím jsem to nesrovnával.
    10.8.2007 10:57 jooke | skóre: 9 | Opava
    Rozbalit Rozbalit vše Re: python skript na regularni vyrazy
    Odzkousim, snad je to to prave... Dekuji
    10.8.2007 15:44 jooke | skóre: 9 | Opava
    Rozbalit Rozbalit vše Re: python skript na regularni vyrazy
    Mam s tim jeste jeden problem, retezec nechci muze byt klidne: Font Server, coz jsou 2 vyrazy a proto se mi neotestuji spravne. pr.
    nechci = ["nologin", "nfs", "lighttpd web server", "Avahi daemon"]

    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.