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:33 | IT novinky

    Po 26 letech od protiprávního policejního zásahu, který byl spuštěn na základě podnětu společnosti Microsoft, Obvodní soud pro Prahu 2 rozsudkem potvrdil, že Mironet prokázal významnou část svého nároku na náhradu škody vůči Ministerstvu spravedlnosti ČR. Soudem nyní přiznaná část nároku znamená rekordní odškodné, jaké kdy české soudy přiznaly za nesprávný postup státu. Spor byl rozdělen na několik škod, u pravomocně uzavřených částí

    … více »
    Ladislav Hagara | Komentářů: 15
    včera 15:22 | Nová verze

    Lehké desktopové prostředí LXQt bylo vydáno ve verzi 2.4.0. Jde o převážně opravné vydání s drobnými vylepšeními podpory Waylandu.

    |🇵🇸 | Komentářů: 0
    včera 12:44 | IT novinky

    Počítačová hra Kingdom Come: Deliverance 2 českého studia Warhorse získala cenu BAFTA v kategorii nejlepší příběh. V konkurenci pěti dalších nominovaných děl porazila i úspěšnou francouzskou hru Clair Obscur: Expedition 33, která v letošním ročníku získala cenu za nejlepší hru roku.

    Ladislav Hagara | Komentářů: 1
    včera 12:22 | Komunita

    Projekt KDE oslaví v říjnu 30 let. Matthias Ettrich poslal 14. října 1996 do diskusní skupiny comp.os.linux.misc zprávu, která započala historii projektu. Důležité milníky jsou zobrazeny na časové ose KDE.

    Ladislav Hagara | Komentářů: 2
    včera 02:55 | Komunita

    Byly vyhlášeny výsledky letošní volby vedoucí/ho projektu Debian (DPL, Wikipedie). Poprvé povede Debian žena. Novou vedoucí je Sruthi Chandran. Letos byla jedinou kandidátkou. Kandidovala již v letech 2020, 2021, 2024 a 2025. Na konferenci DebConf19 měla přednášku Is Debian (and Free Software) gender diverse enough?

    Ladislav Hagara | Komentářů: 16
    včera 00:55 | Nová verze

    Byla vydána nová verze 10.3 z Debianu vycházející linuxové distribuce DietPi pro (nejenom) jednodeskové počítače. Přehled novinek v poznámkách k vydání. Přidána byla podpora Orange Pi 4 LTS. Přibyl balíček Prometheus.

    Ladislav Hagara | Komentářů: 0
    19.4. 18:55 | Nová verze

    Implementace VPN softwaru WireGuard (Wikipedie) pro Windows, tj. WireGuard pro Windows a WireGuardNT, dospěly do verze 1.0.

    Ladislav Hagara | Komentářů: 2
    19.4. 16:11 | IT novinky

    V Pekingu dnes proběhl 2. ročník půlmaratonu humanoidních robotů. První 3 místa obsadili roboti Honor Lightning v různých týmech. Nový rekord autonomního robota je 50 minut a 26 sekund. Operátorem řízený robot to zvládl i s pádem za 48 minut a 19 sekund. Řízení roboti měli časovou penalizaci 20 %. Před rokem nejrychlejší robot zvládl půlmaraton za 2 hodiny 40 minut a 42 sekund. Aktuální lidský rekord drží Jacob Kiplimo z Ugandy s časem 57 minut a 20 sekund [𝕏].

    Ladislav Hagara | Komentářů: 6
    17.4. 17:11 | Zajímavý článek

    Stanislav Fort, vedoucí vědecký pracovník z Vlčkovy 'kyberbezpečnostní' firmy AISLE, zkoumal dopady Anthropic Mythos (nový AI model od Anthropicu zaměřený na hledání chyb, který před nedávnem vyplašil celý svět) a předvedl, že schopnosti umělé inteligence nejsou lineárně závislé na velikosti nebo ceně modelu a dokázal, že i některé otevřené modely zvládly v řadě testů odhalit ve zdrojových kódech stejné chyby jako Mythos (například FreeBSD CVE-2026-4747) a to s výrazně nižšími provozními náklady.

    MakeIranBombedAgain❗ | Komentářů: 8
    17.4. 12:44 | IT novinky

    Federální návrh zákona H.R.8250 'Parents Decide Act', 13. dubna předložený demokratem Joshem Gottheimerem a podpořený republikánkou Elise Stefanik coby spolupředkladatelkou (cosponsor), by v případě svého schválení nařizoval všem výrobcům operačních systémů při nastavování zařízení ověřovat věk uživatelů a při používání poskytovat tento věkový údaj aplikacím třetích stran. Hlavní rozdíl oproti kalifornskému zákonu AB 1043 a kolorádskému SB26-051 je ten, že federální návrh by platil rovnou pro celé USA.

    MakeIranBombedAgain❗ | Komentářů: 13
    Které desktopové prostředí na Linuxu používáte?
     (14%)
     (8%)
     (1%)
     (12%)
     (30%)
     (3%)
     (6%)
     (2%)
     (15%)
     (25%)
    Celkem 1365 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník

    Standardní knihovna pro Python - 5 (řetězce)

    30. 11. 2006 | Jakub Matys | Programování | 8258×

    Po delší odmlce je tu zase pokračování seriálu o knihovně jazyka Python. Dnes začneme další téma - řetězce.

    Po delší odmlce vás vítám u již pátého pokračování seriálu o pythonské knihovně. Dnes se již nebudeme zabývat funkcemi z modulu __builtins__, ale vrhneme se na práci s řetězci. Předpokládám, že většina čtenářů ví, jak se s řetězci pracuje, ale neodpustím si jednoduché opakování.

    V Pythonu je možné pracovat se dvěma typy řetězcových objektů. Prvním typem je obyčejný řetězec, který je 8bitový, a jeho interpretace záleží na nastaveném kódování. Druhým jsou Unicode řetězce. Standardně se skládají z 16bitových znaků, které jsou zakódovány ve formátu UCS-2. Od verze 2.2 je možné používat i 32bitové Unicode řetězce kódované v UCS-4; toto nastavení se však povoluje při překladu interpretru. Mezi oběma typy řetězců je možné provádět konverze. Je možné rovněž konvertovat řetězce z/do jiného kódování než je systémové.

    Nejdříve se začneme zabývat metodami řetězců. Stejné funkce je možné nalézt i v modulu string, ty jsou však už delší dobu označeny jako deprecated (čili nedoporučované).

    Poznámka: Mezi vydáním předchozího a tohoto dílu došlo k uvolnění nové verze Pythonu (v. 2.5). V tomto článku i dalších pokračováních bude na tuto skutečnost brán zřetel a rozdíly mezi jednotlivými verzemi budou komentovány.

    Metody řetězců

    capitalize()

    Metoda vrací novou kopii řetězce, přičemž první písmeno bude velké. Metoda je pro 8bitové řetězce závislá na nastavení locale.

    >>> print "adam".capitalize()
    Adam
    >>> print "říman".capitalize()
    říman
    >>> print u"říman".capitalize()
    Říman
    >>>
    
    center(width[,fillchar])

    Tato metoda vrací také nový řetězec o délce width. Obsah volajícího řetězce je umístěn do jeho středu (vycentrován). Přebývající místo je doplněno znaky fillchar nebo, je-li tento parametr vynechán, mezerami.

    >>> retezec = "Kobyla má malý bok"
    >>> print retezec.center(len(retezec) + 4, '!')
    !!Kobyla má malý bok!!
    >>> print retezec.center(len(retezec) + 3, '!')
    !!Kobyla má malý bok!
    >>> print retezec.center(len(retezec) - 3, '!')
    Kobyla má malý bok
    >>>
    

    Jak je vidět, metoda si poradí i v případě, že vrácený řetězec bude mít lichou délku. V tomto případě se pokusí vycentrovat znaky, jak jen to jde. Předáme-li jako první parametr číslo menší než je délka volajícího řetězce, vrátí se tento řetězec nezměněn.

    Tato metoda byla změněna ve verzi 2.4. Byl přidán argument fillchar.

    count(sub[,start[,end]])

    Spočítá počet výskytů podřetězce sub v řetězci, resp. jeho části definované parametry start a stop.

    decode([encoding[,errors]])

    Metoda dekóduje řetězec do Unicode řetězce. Parametr encoding představuje kodek použitý při dekódování. Je-li vynechán, použije se výchozí kódování (ASCII). Druhý parametr nastavuje způsob, s jakým se bude program vyrovnávat s chybami, které mohou při převádění nastat.

    • 'strict' - nastane-li chyba převodu, vyvolá výjimku UnicodeError (nebo potomka). Tento parametr je výchozí.
    • 'ignore' - přeskočí chybný znak a pokračuje převodem následujícího.
    • 'replace' - nahradí chybný znak znakem REPLACEMENT CHARACTER (U+FFFD).

    Parametry ignore a replace jsou použitelné pouze pro chyby vznikající při převodu. Je-li chyba způsobená neodpovídajícím vstupem, je vyhozena výjimka UnicodeError bezpodmínečně. Například kódování iso-8859-2 a cp1250 nejsou 100% přenositelná. A nechcete-li, aby byla při objevení nekompatibilního znaku vždy vyvolávána výjimka, můžete použít dva výše zmíněné parametry. V prvním případě bude znak ignorován, ve druhém nahrazen.

    Použijete-li však řetězec s diakritikou a nastavíte jej jako ASCII, bude vždy vyvolána výjimka. Při převodu z ASCII kódování se totiž kontroluje, zda je hodnota znaku menší než 128 (rozsah základní ASCII je 0 - 127).

    Metoda byla přidána do Pythonu ve verzi 2.2 a ve verzi 2.3 byl přidán parametr errors.

    >>> unicode = "kobyla má malý bok".decode("utf-8") # utf-8 => unicode
    >>> unicode
    u'kobyla m\xe1 mal\xfd bok'
        # odpovidajici unicode retezec
    
    >>> print unicode
    kobyla má malý bok
        # zde je videt, ze byl retezec zkonvertovan spravne
    
    >>> iso = "kobyla má malý bok".decode("iso8859-2")
        # iso-8859-2 => unicode
    >>> iso
    u'kobyla m\u0102\u0104 mal\u0102\u02dd bok'
    >>> # za kazdy cesky znak se ulozi 2 unicode znaky,
    ... # protoze me nastaveni locale je utf8 (neASCII
    ... # znaky jsou vice bytove), ale pri prevodu bylo
    ... # zadano kodovani iso8859-2 (1 bytove)
    ...
    >>> print iso
    kobyla mĂĄ malĂ˝ bok
    >>> "kobyla má malý bok".decode()
        # neodpovidajici vstup, viz odstavec vyse
    Traceback (most recent call last):
      File "<stdin>", line 1, in ?
    UnicodeDecodeError: 'ascii' codec can't decode byte 0xc3 in position 8:
     ordinal not in range(128)
    >>>
    
    encode([encoding[,errors]])

    Metoda encode pracuje opačně než decode. Unicode nebo obyčejný řetězec je zkonvertován do kódování encoding. Pokud budeme konvertovat standardní řetězec, nesmíme zapomenout, že řetězec bude interpretován ve standardním kódování (ASCII). Pro parametr erorrs platí to samé jako u decode, ale přibývají ještě parametry 'xmlcharrefreplace' a 'backslashreplace'. První zakóduje "neobvyklé" znaky (diakritika atd.) pro použití v XML nebo HTML (&#číslo;), druhý použije lomítkovou interpretaci (\\xe1, kde e1 je hexadecimální kód znaku á).

    Všechna použitelná kódování je možné nalézt v sekci 4.8.3 Python Library Reference.

    Metoda je součástí jazyka od verze 2.0. Parametry xmlcharrefreplace a backslashreplace byly přidány ve verzi 2.3.

    >>> retezec = u"kobyla má malý bok"
    >>> retezec.encode("utf-8") # unicode => utf-8
    'kobyla m\xc3\xa1 mal\xc3\xbd bok'
    >>> retezec.encode("iso-8859-2") # unicode => iso-8859-2
    'kobyla m\xe1 mal\xfd bok'
    
    >>> retezec.encode("ascii") # ta sama chyba jako u decode
    Traceback (most recent call last):
      File "", line 1, in ?
    UnicodeEncodeError: 'ascii' codec can't encode character u'\xe1'
     in position 8: ordinal not in range(128)
    
    >>> retezec.encode("ascii", "ignore")
        # na rozdil od decode v tomto pripade funguje 'ignore'
    'kobyla m mal bok'
    
    >>> retezec.encode("ascii", "replace") # i 'replace'
    'kobyla m? mal? bok'
    
    >>> retezec.encode("ascii", "xmlcharrefreplace")
        # rozkodovani pro pouziti na webu
    'kobyla má malý bok'
    
    >>> retezec.encode("ascii", "backslashreplace")
        # a s lomitkovou interpretaci
    'kobyla m\\xe1 mal\\xfd bok'
    
    >>> "kobyla ma maly bok".encode() # ASCII => ASCII
    'kobyla ma maly bok'
    >>> "kobyla ma maly bok".encode("utf-8") # ASCII => utf-8
    'kobyla ma maly bok'
    >>> print "kobyla ma maly bok".encode("utf-8")
    kobyla ma maly bok
    >>>
    
    endswith(suffix[,start[,end]])

    Vrací True, pokud řetězec nebo jeho část [start:end] končí na suffix. Ve verzi 2.5 byla přidána možnost zadat suffix jako n-tici řetězců, které se budou kontrolovat.

    expandtabs([tabsize])

    Vrací novou kopii řetězce, ve kterém jsou všechny tabulátory nahrazeny mezerami. Počet těchto mezer je udán parametrem tabsize. Je-li tento vynechán, je počet mezer standardně nastaven na 8.

    A zde dnešní díl končí. Příště budeme pokračovat dalšími metodami.

    Nejčtenější články posledního měsíce

    Týden na ScienceMag.cz: Modely umělé inteligence založené na fyzice místo na jazyce by se mohly stát hnací silou vědeckých objevů
    Týden na ITBiz: Nová technologie dokáže sledovat lidi podle toho, jak narušují signály Wi-Fi
    Týden na ITBiz: Trh s externími úložišti rostl solidně

    Nejkomentovanější články posledního měsíce

    Jaderné noviny – přehled za únor 2026
    Týden na ScienceMag.cz: Modely umělé inteligence založené na fyzice místo na jazyce by se mohly stát hnací silou vědeckých objevů
      všechny statistiky »

    Seriál Standardní knihovna pro Python (dílů: 8)

    Standardní knihovna pro Python - 1 (builtins) (první díl)
    <—« Standardní knihovna pro Python - 4 (builtins 4)
    »—> Standardní knihovna pro Python - 6 (řetězce 2)
    Standardní knihovna pro Python - 8 (regulární výrazy 1) (poslední díl)

    Související články

    Standardní knihovna pro Python - 1 (builtins)
    Standardní knihovna pro Python - 2 (builtins 2)
    Standardní knihovna pro Python - 3 (builtins 3)
    Standardní knihovna pro Python - 4 (builtins 4)
    Ruby pro začátečníky - 1
    Seriál: BASH
    Python a PyQt - 1 (úvod)
    Python a PyQt - 2 (podmínky, cykly, tlačítka)
    Začínáme programovat v jazyce Python
    Kommander - 1 (Skriptované GUI)
    Kommander - 2 (Starý parser)
    Kommander - 3 (Nový parser)
    Seriál: Začíname KProgramovať
    Programujeme v PERLu - I
    Programujeme v PERLu - II

    Další články z této rubriky

    LLVM a Clang – více než dobrá náhrada za GCC
    Ze 4 s na 0,9 s – programovací jazyk Vala v praxi
    Reverzujeme ovladače pro USB HID zařízení
    Linux: systémové volání splice()
    Programování v jazyce Vala - základní prvky jazyka
           

    Hodnocení: 100 %

            špatnédobré        

    Nástroje: Tisk bez diskuse

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    Komentáře

    Vložit další komentář

    30.11.2006 18:03 Jan Tichavský
    Rozbalit Rozbalit vše Re: Standardní knihovna pro Python - 5 (řetězce)
    Díky za seriál, bude se mi hodit. Může mi někdo poradit, jak poznám, jestli znak jde převést na číslo (tj. je 0-9)? Je nějaká obecná metoda jak to udělat i pro jiné jazyky (kromě zjistění ASCII kódu 0-9 a porovnání)?
    Vojta Drbohlav avatar 30.11.2006 19:28 Vojta Drbohlav | skóre: 26 | blog: Blog | Strahov
    Rozbalit Rozbalit vše Re: Standardní knihovna pro Python - 5 (řetězce)
    >>> i = "5"
    >>> i.isdigit()
    True
    >>>
    30.11.2006 23:07 J.
    Rozbalit Rozbalit vše Re: Standardní knihovna pro Python - 5 (řetězce)
    jo, to je ono, díky
    1.12.2006 09:36 Hynek (Pichi) Vychodil | skóre: 43 | blog: Pichi | Brno
    Rozbalit Rozbalit vše Re: Standardní knihovna pro Python - 5 (řetězce)
    Pro perl třeba $a =~ /^[+-]?\d+(?:\.\d+)?/ a nebo mnohem lépe a radostněji
    use Scalar::Util qw(looks_like_number);
    ...
    if (looks_like_number($a)) {
        ...
    } else {
        ...
    }
    ...
    XML je zbytečný, pomalý, nešikovný balast, znovu vynalézané kolo a ještě ke všemu šišaté, těžké a kýčovitě pomalované.
    Vojta Drbohlav avatar 1.12.2006 16:38 Vojta Drbohlav | skóre: 26 | blog: Blog | Strahov
    Rozbalit Rozbalit vše Re: Standardní knihovna pro Python - 5 (řetězce)
    $a =~ /^[+-]?\d+(?:\.\d+)?/
    No fuj... :-D
    1.12.2006 18:10 amnesiac
    Rozbalit Rozbalit vše Re: Standardní knihovna pro Python - 5 (řetězce)
    print "$a je cislo" if ($a eq ($a + 0))

    Akorát je neošetřeno explicitní uvedení znaménka + .

    4.12.2006 10:48 Hynek (Pichi) Vychodil | skóre: 43 | blog: Pichi | Brno
    Rozbalit Rozbalit vše Re: Standardní knihovna pro Python - 5 (řetězce)
    Akorát je neošetřeno explicitní uvedení znaménka + .
    Ano, taková nepodstatná maličkost, když můžeme použít interní funkci perl api looks_like_number na nímž je Scalar::Util::looks_like_number pouze wrapper. Místo toho necháme perl zavolat tuto funkci hned dvakrát, pokusíme se o sčítání a nakonec ještě budeme porovnávat řetězce s tím výsledkem, že to nefunguje pro všechny případy (hloupé + na začátku). Aneb jak to dělat jednoduše, když to jde složitě, že?
    XML je zbytečný, pomalý, nešikovný balast, znovu vynalézané kolo a ještě ke všemu šišaté, těžké a kýčovitě pomalované.
    7.12.2006 18:18 J.
    Rozbalit Rozbalit vše Re: Standardní knihovna pro Python - 5 (řetězce)
    Jelikož název funkce je dost výstižný, líbí se mi to víc a to v Perlu vůbec nedělám. Samozřejmě všechno lze dělat několika způsoby a v Perlu i zvlášť nepřehledně (neříkám, že každý to tak dělá) :)
    3.12.2006 19:22 mys elf
    Rozbalit Rozbalit vše Re: Standardní knihovna pro Python - 5 (řetězce)
    V C existuje funkce isdigit() (v ctype.h).
    30.11.2006 23:56 Lukoko | skóre: 8 | blog: Lukoko | Praha
    Rozbalit Rozbalit vše Re: Standardní knihovna pro Python - 5 (řetězce)
    osobne mam rad u stringu tudle metodu:
    >>> a=["1","2","3","a","b"]
    >>> ", ".join(a)
    '1, 2, 3, a, b'
    >>> 
    
    Mac OS X je taky unix

    Založit nové vláknoNahoru

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.