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:22 | Humor

    Na novoroční inauguraci starosty New Yorku Zohrana Mamdaniho bylo zakázáno si s sebou přinést Raspberry Pi anebo Flipper Zero. Raspberry Pi i Flipper Zero jsou explicitně uvedeny v seznamu zakázaných věcí jak na na veřejné pozvánce, tak i na oficiálních stránkách města.

    NUKE GAZA! 🎆 | Komentářů: 0
    dnes 11:33 | Nová verze

    OpenTTD (Wikipedie), tj. open source klon počítačové hry Transport Tycoon Deluxe, byl vydán v nové stabilní verzi 15.0. Přehled novinek v seznamu změn a také na YouTube. OpenTTD lze instalovat také ze Steamu.

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

    Správce oken IceWM byl vydán ve verzi 4.0.0, která např. vylepšuje navigaci v přepínání velkého množství otevřených oken.

    |🇵🇸 | Komentářů: 0
    dnes 01:33 | Zajímavý projekt

    Od 1. ledna 2026 jsou všechny publikace ACM (Association for Computing Machinery) a související materiály přístupné v její digitální knihovně. V rámci této změny je nyní digitální knihovna ACM nabízena ve dvou verzích: v základní verzi zdarma, která poskytuje otevřený přístup ke všem publikovaným výzkumům ACM, a v prémiové zpoplatněné verzi, která nabízí další služby a nástroje 'určené pro hlubší analýzu, objevování a organizační využití'.

    NUKE GAZA! 🎆 | Komentářů: 4
    včera 16:44 | IT novinky

    S koncem roku 2025 skončila standardní podpora operačního systému HP-UX (Hewlett Packard Unix).

    Ladislav Hagara | Komentářů: 10
    včera 14:33 | Nová verze

    K 1. lednu 2026 končí 70leté omezení majetkových autorských práv děl autorů zesnulých v roce 1955, viz 2026 in public domain. V americkém prostředí vstupují do public domain díla z roku 1930, viz Public Domain Day.

    |🇵🇸 | Komentářů: 1
    31.12. 15:00 | Nová verze

    Všem vše nejlepší do nového roku 2026.

    Ladislav Hagara | Komentářů: 10
    31.12. 13:33 | Zajímavý software

    Crown je multiplatformní open source herní engine. Zdrojové kódy jsou k dispozici na GitHubu pod licencí MIT a GPLv3+. Byla vydána nová verze 0.60. Vyzkoušet lze online demo.

    Ladislav Hagara | Komentářů: 0
    31.12. 12:11 | Zajímavý článek

    Daniel Stenberg na svém blogu informuje, že po strncpy() byla ze zdrojových kódů curlu odstraněna také všechna volání funkce strcpy(). Funkci strcpy() nahradili vlastní funkcí curlx_strcopy().

    Ladislav Hagara | Komentářů: 6
    31.12. 03:00 | Nová verze

    Byla vydána nová verze 25.12.30 svobodného multiplatformního video editoru Shotcut (Wikipedie) postaveného nad multimediálním frameworkem MLT. Shotcut je vedle zdrojových kódů k dispozici také ve formátech AppImage, Flatpak a Snap.

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (0%)
     (4%)
     (0%)
     (25%)
     (29%)
     (21%)
     (4%)
     (4%)
     (11%)
     (18%)
    Celkem 28 hlasů
     Komentářů: 1, poslední dnes 06:15
    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.