LINUXSOFT.cz Přeskoč levou lištu
Uživatel: Heslo:  
   CZUKPL

> Python (4.) - Operátory

Prostředkem pro nejzákladnější operace s daty jsou ve většině imperativních jazyků operátory, nejinak je tomu v Pythonu.

28.12.2004 15:00 | Aleš Hakl | Články autora | přečteno 8410×

V pythonu kromě běžných unárních a binárních operátorů existují konstrukce, které ačkoli syntakticky jsou spíše voláním funkce, z pohledu Pythonu se jedná spíše o operátory. Tento rozdíl uvidíme v pozdějších dílech při objektově orientovaném programování.

Aritmetické operátory

Za úplně nejzákladnější operace (pokud vynecháme přiřazení vysvětlené v minulém dílu) můžeme bezpochyby považovat aritmetiku, zde nám Python nabízí základní operátory +, -, * a / a navíc zbytek po celočíselném dělení reprezentovaný operátorem %. Dalším aritmetickým operátorem je ** zajišťující umocňování. Nemusím doufám zdůrazňovat existenci unárních operátorů + a -.

>>> 1+1
2
>>> 2*2
4
>>> 2-1
1
>>> 5%2
1

>>> 2**8
256

Výsledkem dělení celých čísel je opět celé číslo, které je vždy zaokrouhleno dolů.

Pro aritmetické operace také existuje několik výše zmíněných "pseudo-operátorů", jsou to:

  • abs(x) - Absolutní hodnota argumentu
  • int(x) - Konverze na datový typ int
  • long(x) - Opět konverze, tentokrát na datový typ long
  • float(x) - a opět...
  • divmod(dělenec, dělitel) - Kombinace operací dělení a zbytku po celočíselném dělení, výsledkem je n-tice o dvou položkach (tedy dvojice ^_^) v pořadí (podíl, zbytek).
  • pow(základ, exponent) - Mocnina

Logické operace

Co by Python byl za programovací jazyk, pokud by neumožňoval provádět logické operace. Python umí s logickými hodnotami provádět základní booleovské operace or, and a not. Priorita operátoru odpovídá pořadí ve výše uvedeném seznamu.

>>> True
True
>>> True and False
False
>>> True or False
True
>>> not True
False

Bitové operace

Python také umí provádět logické operace na jednotlivých bitech čísla. Tyto operace je možné provádět na datových typech int a long.

  • x | y - logický součet (OR)
  • x ^ y - non-ekvivalence (XOR)
  • x & y - logický součin (AND)
  • x << počet_bitů - bitový posun doleva
  • x >> počet_bitů -bitový posun doprava
  • ~x - negace (NOT)

Priorita opět odpovídá výše uvedenému seznamu.

>>> 128 << 3
1024
>>> 128 >> 3

16
>>> 128 & 64
0
>>> 192 & 64
64
>>> 192 | 64
192

>>> 192 ^ 64
128

Sekvence

Pro sekvence (tj. ne jenom řetězce ale i například seznamy) zavádí Python poměrně velké množství operátorů umožnujicích provadět občas i poněkud netradiční operace.

  • prvek in sekvence - Zjistí jestli sekvence obsahuje daný prvek
  • prvek not in sekvence - totéž jako předchozí, pouze vratí True pokud sekvence daný prvek neobsahuje.
  • x + y - Spojí dvě sekvence za sebe.
  • sekvence * počet nebo počet * sekvence - Okopíruje sekvenci několikrát za sebe.
  • sekvence[index] - Vráti prvek určený indexem
  • sekvence[první:poslední] - Vráti sekvenci obsahující všechny prvky z daného rozsahu původní sekvence.
  • sekvence[první:poslední:krok] - Vratí sekvenci obsahující prvky s určeným rozestupem z daného rozsahu původní sekvence.
  • len(sekvence) - Počet prvků sekvence
  • min(sekvence) - Nejmenší prvek sekvence
  • max(sekvence) - Největší prvek sekvence

Že uhodnete podle čeho poznáte prioritu těchto operátorů?

Pro měnitelné sekvence je možné použít všechny operátory s hranatými závorkami na levé straně přiřazovacího příkazu. Dále je zaveden unární operátor del, kterým se da ze sekvence mazat pomocí syntaxe del sekvence[index], případně je též možné mazat prvky v nějakém rozsahu prostřednictvím dvojtečky.

>>> 'a' in ['a', 'b']
True
>>> 'a' not in ('a','b')
False
>>> ('a','b') * 3
('a', 'b', 'a', 'b', 'a', 'b')
>>> s = ('a','b')
>>> s[0]

'a'
>>> t = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
>>> t[5:9]
[5, 6, 7, 8]
>>> t[5:9:2]
[5, 7]
>>> len(t)
10
>>> min(t)

0
>>> max(s)
'b'

V příštím díle se konečně podíváme na něco, co se dá nazvat progarmováním, a to některé v jazyce Python přítomné řídící struktury.

Verze pro tisk

pridej.cz

 

DISKUZE

++ -- 9.1.2005 14:56 Josef Kufner
  L Re: ++ -- 9.1.2005 16:10 Aleš Hakl




Příspívat do diskuze mohou pouze registrovaní uživatelé.
> Vyhledávání software
> Vyhledávání článků
> Služby
Administrace serverů
Od 350 Kč/hod
Server housing
Od 1000 Kč/1U

30.7.2010 9:06 /MaReK Olšavský
Krátký článek pro pythonýry připomíná zlatá pravidla programování (vztažitelná i na jiné jazyky). Pokračujte odkazem na konci článku :-).
Přidat komentář

29.7.2010 14:39 /Radim Kolář
IBM vydala další z řady publikací pro studenty Getting started with open source development. Probírají se licence, obchodní modely, příklady OSS projektů a jak se zapojit do vývoje. Dodatek je věnován krátkému úvodu k DB2 databázi.
Přidat komentář

29.7.2010 7:44 /MaReK Olšavský
Při procesu akvizice SUN Microsystems Oraclem se mluvilo především o MySQL a Java platformě, ale Oracle získal mnohem více zajímavých produktů se širokou uživatelskou základnou, například VirtualBox, ke kterému má poněkud macešský přístup. Bude tu VirtualBox pro běžné uživatele, nebo se s ním máme pomalu rozloučit?
Komentářů: 1

29.7.2010 7:08 /MaReK Olšavský
Pokud se uživatelé distribucí Fedora a Ubuntu těšili na pozimní vydání, která měla přinést GNOME 3.0, mohou svá očekávání zmírnit, GNOME 3.0 bude opožděno, snad jen do března 2011.
Přidat komentář

28.7.2010 8:49 /MaReK Olšavský
Možná pro někoho může být překvapující, že CentOS má majoritní podíl mezi webservery. „Bezplatný RHEL“ trochu překvapivě předstihl vyzdvihovaný Debian i FreeBSD.
Komentářů: 5

   Více ...   Přidat zprávičku

> Poslední diskuze

29.7.2010 18:24 / Hynek (Pichi) Vychodil
Re: Kým vyzdvihovaný Debian?

29.7.2010 15:29 / Radim Kolář
Re: Ruchlost kompilace

29.7.2010 12:40 / Radim Kolář
Freebsd

29.7.2010 12:35 / Radim Kolář
mne pada

29.7.2010 12:35 / Slavomir
Rychla maska

Více ...

ISSN 1801-3805 | Prague hotels | Provozovatel: Pavel Kysilka, IČ: 72868490 (2003-2010) | mail at linuxsoft dot cz | Design: www.megadesign.cz | Textová verze