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 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ářů: 0
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ářů: 0
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ářů: 1
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ářů: 0
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
16.10. 22:04 | Pozvánky

Rádi bychom vás pozvali na přednášku o frameworku Avocado. Jedná se o testovací framework další generace, inspirovaný Autotestem a moderními vývojovými nástroji, jako je třeba git. Přednáška se bude konat 23. října od 17 hodin na FEL ČVUT (Karlovo náměstí, budova E, auditorium K9 – KN:E 301). Více informací na Facebooku.

… více »
mjedlick | Komentářů: 0
Jak se vás potenciálně dotkne trend odstraňování analogového audio konektoru typu 3,5mm jack z „chytrých telefonů“?
 (13%)
 (0%)
 (0%)
 (3%)
 (75%)
 (9%)
Celkem 32 hlasů
 Komentářů: 1, poslední dnes 11:21
    Rozcestník

    Dotaz: Python - regulární výraz

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

    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.