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 19:44 | Nová verze

    Byla vydána verze 9.1 open source virtualizační platformy Proxmox VE (Proxmox Virtual Environment, Wikipedie) založené na Debianu. Přehled novinek v poznámkách k vydání a informačním videu.

    Ladislav Hagara | Komentářů: 1
    včera 17:44 | IT novinky

    Byl aktualizován seznam 500 nejvýkonnějších superpočítačů na světě TOP500. Nejvýkonnějším superpočítačem zůstává El Capitan od HPE (Cray) s výkonem 1,809 exaFLOPS. Druhý Frontier má výkon 1,353 exaFLOPS. Třetí Aurora má výkon 1,012 exaFLOPS. Nejvýkonnější superpočítač v Evropě JUPITER Booster s výkonem 1,000 exaFLOPS je na čtvrtém místě. Nejvýkonnější český superpočítač C24 klesl na 192. místo. Karolina, GPU partition klesla na 224. místo a Karolina, CPU partition na 450. místo. Další přehledy a statistiky na stránkách projektu.

    Ladislav Hagara | Komentářů: 1
    včera 17:22 | IT novinky

    Microsoft představil Azure Cobalt 200, tj. svůj vlastní SoC (System-on-Chip) postavený na ARM a optimalizovaný pro cloud.

    Ladislav Hagara | Komentářů: 0
    včera 12:00 | IT novinky

    Co způsobilo včerejší nejhorší výpadek Cloudflare od roku 2019? Nebyl to kybernetický útok. Vše začalo změnou oprávnění v jednom z databázových systémů a pokračovalo vygenerováním problém způsobujícího konfiguračního souboru a jeho distribucí na všechny počítače Cloudflare. Podrobně v příspěvku na blogu Cloudflare.

    Ladislav Hagara | Komentářů: 3
    18.11. 23:44 | Nová verze

    Byla vydána (Mastodon, 𝕏) první RC verze GIMPu 3.2. Přehled novinek v oznámení o vydání. Podrobně v souboru NEWS na GitLabu.

    Ladislav Hagara | Komentářů: 0
    18.11. 23:22 | Komunita

    Eugen Rochko, zakladatel Mastodonu, tj. sociální sítě, která není na prodej, oznámil, že po téměř 10 letech odstupuje z pozice CEO a převádí vlastnictví ochranné známky a dalších aktiv na neziskovou organizaci Mastodon.

    Ladislav Hagara | Komentářů: 0
    18.11. 19:44 | Nová verze

    Byla vydána nová major verze 5.0 svobodného 3D softwaru Blender. Přehled novinek i s náhledy a videi v obsáhlých poznámkách k vydání. Videopředstavení na YouTube.

    Ladislav Hagara | Komentářů: 0
    18.11. 14:00 | Upozornění

    Cloudflare, tj. společnost poskytující "cloudové služby, které zajišťují bezpečnost, výkon a spolehlivost internetových aplikací", má výpadek.

    Ladislav Hagara | Komentářů: 13
    18.11. 04:22 | Pozvánky

    Letos se uskuteční již 11. ročník soutěže v programování Kasiopea. Tato soutěž, (primárně) pro středoškoláky, nabízí skvělou příležitost procvičit logické myšlení a dozvědět se něco nového ze světa algoritmů – a to nejen pro zkušené programátory, ale i pro úplné začátečníky. Domácí kolo proběhne online od 22. 11. do 7. 12. 2025 a skládá se z 9 zajímavých úloh různé obtížnosti. Na výběru programovacího jazyka přitom nezáleží – úlohy jsou

    … více »
    SoutezKasiopea | Komentářů: 1
    18.11. 04:11 | Nová verze

    Byla vydána nová verze 2.52.0 distribuovaného systému správy verzí Git. Přispělo 94 vývojářů, z toho 33 nových. Přehled novinek v příspěvku na blogu GitHubu a v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    Jaké řešení používáte k vývoji / práci?
     (35%)
     (46%)
     (19%)
     (18%)
     (23%)
     (15%)
     (23%)
     (15%)
     (17%)
    Celkem 371 hlasů
     Komentářů: 17, poslední včera 21:57
    Rozcestník

    Dotaz: Python - regulární výraz

    7.1.2008 15:32 Bobo
    Python - regulární výraz
    Přečteno: 1961×

    Zdravím,
    potřeboval bych poradit s regulárním výrazem v Pythonu (mám verzi 2.5), který by podle mne měl být velmi snadný, přesto se mi však stále nedaří, aby fungoval tak, jak chci.

    Konkrétně potřebuji, abych v řetězci našel takovou sekvenci znaků, která najde v řetěci číslo, ovšem s podmínkou, že před číslem nesmí být sekvence znaků "log" a za číslem nesmí být znak ".".

    Pro lepší pochopení problému to bude sloužit k nahrazení nalezeného čísla za číslo ve tvaru float, teda za nalezené číslo přidám ".0". Výjimky jsou zřejmé: nechci nahradit "log10" za "log10.0" a nechci nahradit číslo, které již ve tvaru float je. Nahrazování hodím do cyklu a tím se postupně nahradí všechna int čísla.

    Já bych to úplně chápal takto, ovšem Python ne :)

    import re
    str = 'retezec 246 obsahujici 4564 cisla a vyjimky: log10 5.2'
    p = re.compile("^(log)([0-9]+)(^.)")
    print re.match(p, str)
    n=re.match(p, str)
    if n: print n.group(1)

    Mimochodem je jasné, že v tomto pokusném zdrojáku nemám cyklus, a proto dojde jen k nalezení první odpovídající sekvence znaků.

    Mnohokrát děkuji za pomoc.

    Odpovědi

    7.1.2008 16:16 happy barney | skóre: 34 | blog: dont_worry_be_happy
    Rozbalit Rozbalit vše Re: Python - regulární výraz
    (?<=log)[0-9]+(?=\.)
    7.1.2008 16:23 happy barney | skóre: 34 | blog: dont_worry_be_happy
    Rozbalit Rozbalit vše Re: Python - regulární výraz
    oprava ... miesto = v oboch prípadoch použiť !
    7.1.2008 17:59 Bobo
    Rozbalit Rozbalit vše Re: Python - regulární výraz

    Moc díky, funguje to zatím nejlíp ze všech mých pokusů... :) Ale narazil jsem na tři problémy, popsané v komentářích. Jsem fakt amatér v regulárních výrazech (ale než jsem se zde zeptal, studoval jsem samozřejmě manuál, ale např. to "?<=" jsem v něm vůbec nenašel), tak nevím, jestli to jimi vůbec jde (ty tři problémy), nebo si s tím budu muset pohrát pomocí podmínek. Díky moc, věřím, že zkušeným to zabere jen pár vteřin...
    (mimochodem, už chápu, proč jsi napsal = místo !, já taky musel...)

    import re str = 'nejake znaky 6.0 '
    p = re.compile("(?<=log)([0-9]+)(?=\.)")
    print re.search(p, str)
    n=re.search(p, str)
    if n: print n.group(1)

    #pokud je tam 246.0 najde 24, pokud je tam napr. log123, najde 23, potreboval bych, aby ignoroval cele cislo
    #jeste problem: najde cislo/cisla za znakem "."

    7.1.2008 20:33 happy barney | skóre: 34 | blog: dont_worry_be_happy
    Rozbalit Rozbalit vše Re: Python - regulární výraz
    ad log123 ... pomôže pridaná podmienka nečíslo alebo hranica slova ... (?<!log)((?<=\D)|\b)(\d+) (dúfam, že to python pozná, používam perl)
    druhú stranu bude treba ošetriť podobne.
    problém "číslo za bodkou" by sa dal riešiť vložením (?<!\.)
    7.1.2008 20:38 happy barney | skóre: 34 | blog: dont_worry_be_happy
    Rozbalit Rozbalit vše Re: Python - regulární výraz
    finálna verzia: (?<!log)(?<!\d)(?<!\d\.)(\d+) (dnes už naposledy)
    8.1.2008 22:41 bobo.rimis
    Rozbalit Rozbalit vše Re: Python - regulární výraz

    Ještě pořád to dělá 2 věci, které si nepřeji:
    pokud je tam 12.345, najde 1
    pokud je tam 1.2345, nejde 2345

    Jinak mnohokrát děkuji, na tyto dvě chyby bych už možná přišel sám, ale kdyby ne, tak by už tento dotaz nebyl aktuální a byl by považován za vyřešený (což jsem zrušil). Děkuji za pochopení ;)

    8.1.2008 22:43 bobo.rimis
    Rozbalit Rozbalit vše Re: Python - regulární výraz

    A já bych potřeboval, aby to v těchto případech nenašlo nic. (pro jistotu doplňuji...)

    9.1.2008 01:38 Dunric | skóre: 21
    Rozbalit Rozbalit vše Re: Python - regulární výraz
    str = 'retezec 246 obsahujici 4564 cisla a vyjimky: log10 5.2'	# cokoliv
    p = re.compile('(?<!log)(?<!\.)(?<!\d)\d+(?!\d)(?!\.)')	  # osetrit vsechny pripady
    n = p.findall(str)
    if n:
    	for fixn in n:
    		…
    
    Dále viz re.sub .
    In the garden sleeps a messenger ·
    9.1.2008 16:42 bobo.rimis
    Rozbalit Rozbalit vše Re: Python - regulární výraz

    Mnohokrát Ti děkuji! Fakt jo, vyřešil jsi můj problém, se kterým už jsem se vážně dlouho trápil a nikdo mi nedokázal pomoci. Funguje to přesně tak, jak jsem chtěl. Jen bych byl ještě moc vděčný za slovní popis toho regulárního výrazu, abych to dokonale pochopil a příště se nemusel ptát... ;)

    Jinak tady je ten prográmek, kvůli kterému jsem to potřeboval:

    retez=raw_input("Zadej retezec: ")
    import re
    import string
    reg = re.compile("(?<!log)(?<!\.)(?<!\d)(\d+)(?!\d)(?!\.)")
    while reg.search(retez):
    x = reg.search(retez)
    nalez = str(x.group(1))
    novy=nalez+".0"
    retez=string.replace(retez, nalez, novy, 1)
    print retez

    Ještě jednou díky :)

    9.1.2008 19:46 Dunric | skóre: 21
    Rozbalit Rozbalit vše Re: Python - regulární výraz
    Myslím že je to jasné přímo z oficiální dokumentace .

    Ve zkratce jde o to, že ta sekvence čísel nejen nesmí následovat za "log" a předcházet tečce, ale zároveň nesmí předcházet a následovat jakékoliv číslici a i následovat tečce, jinak dostaneš fragmenty, které zjevně odpovídají té úvodní podmínce.

    In the garden sleeps a messenger ·
    9.1.2008 19:47 Dunric | skóre: 21
    Rozbalit Rozbalit vše Re: Python - regulární výraz
    s/odpovídají/vyhovují/
    In the garden sleeps a messenger ·

    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.