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 15:00 | Zajímavý článek

    Byl publikován přehled vývoje renderovacího jádra webového prohlížeče Servo (Wikipedie) za uplynulé dva měsíce. Servo zvládne už i Gmail. Zakázány jsou příspěvky generované pomocí AI.

    Ladislav Hagara | Komentářů: 1
    9.5. 17:22 | Nová verze

    Raspberry Pi Connect, tj. oficiální služba Raspberry Pi pro vzdálený přístup k jednodeskovým počítačům Raspberry Pi z webového prohlížeče, byla vydána v nové verzi 2.5. Nejedná se už o beta verzi.

    Ladislav Hagara | Komentářů: 0
    9.5. 15:22 | Komunita

    Google zveřejnil seznam 1272 projektů (vývojářů) od 185 organizací přijatých do letošního, již jednadvacátého, Google Summer of Code. Plánovaným vylepšením v grafických a multimediálních aplikacích se věnuje článek na Libre Arts.

    Ladislav Hagara | Komentářů: 0
    8.5. 19:22 | Nová verze

    Byla vydána (𝕏) dubnová aktualizace aneb nová verze 1.100 editoru zdrojových kódů Visual Studio Code (Wikipedie). Přehled novinek i s náhledy a videi v poznámkách k vydání. Ve verzi 1.100 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.

    Ladislav Hagara | Komentářů: 0
    8.5. 18:00 | Nová verze

    Open source platforma Home Assistant (Demo, GitHub, Wikipedie) pro monitorování a řízení inteligentní domácnosti byla vydána v nové verzi 2025.5.

    Ladislav Hagara | Komentářů: 0
    8.5. 01:22 | Nová verze Ladislav Hagara | Komentářů: 0
    8.5. 00:55 | Zajímavý projekt

    PyXL je koncept procesora, ktorý dokáže priamo spúštat Python kód bez nutnosti prekladu ci Micropythonu. Podľa testov autora je pri 100 MHz približne 30x rýchlejší pri riadeni GPIO nez Micropython na Pyboard taktovanej na 168 MHz.

    vlk | Komentářů: 0
    7.5. 19:44 | Nová verze

    Grafana (Wikipedie), tj. open source nástroj pro vizualizaci různých metrik a s ní související dotazování, upozorňování a lepší porozumění, byla vydána ve verzi 12.0. Přehled novinek v aktualizované dokumentaci.

    Ladislav Hagara | Komentářů: 0
    7.5. 17:33 | Nová verze

    Raspberry Pi OS, oficiální operační systém pro Raspberry Pi, byl vydán v nové verzi 2025-05-06. Přehled novinek v příspěvku na blogu Raspberry Pi a poznámkách k vydání. Pravděpodobně se jedná o poslední verzi postavenou na Debianu 12 Bookworm. Následující verze by již měla být postavena na Debianu 13 Trixie.

    Ladislav Hagara | Komentářů: 0
    7.5. 05:33 | Komunita

    Richard Stallman dnes v Liberci přednáší o svobodném softwaru a svobodě v digitální společnosti. Od 16:30 v aule budovy G na Technické univerzitě v Liberci. V anglickém jazyce s automaticky generovanými českými titulky. Vstup je zdarma i pro širokou veřejnost.

    Ladislav Hagara | Komentářů: 17
    Jaký filesystém primárně používáte?
     (57%)
     (1%)
     (8%)
     (22%)
     (4%)
     (2%)
     (2%)
     (1%)
     (1%)
     (3%)
    Celkem 577 hlasů
     Komentářů: 26, poslední 8.5. 09:58
    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: 533×
    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.