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

> Python (2.) - Datové typy

Jazyk Python rozlišuje různé datové typy, dnes se podíváme na ty základní: čísla, řetězce, seznamy, slovníky a n-tice.

16.11.2004 09:00 | Aleš Hakl | Články autora | přečteno 10573×

Ačkoli jazyk Python rozlišuje různé datové typy, je možné do libovolné proměnné uložit hodnotu libovolného typu. Narozdíl od jayzků jako PHP nebo Perl nedochází tak často k automatickým konverzím a často si potřebnou konverzi musíme vynutit sami explicitně.

Čísla

V Pythonu můžeme nalézt několik různých číselných typů:

  • Celé číslo (integer)
  • Dlouhé celé číslo (long integer)
  • Reálné číslo
  • Komplexní číslo

Pokud přímo do programu zapíšeme nějakou hodnotu, jedná se o celé číslo nebo reálné, ostaní typy si musíme sami vynutit:

1    # celé číslo

3.14 # reálné číslo (číslo v plovoucí řádové čárce)
1L   # dlouhé delé číslo
1+1j # komplexní číslo
1j   # také komplexní číslo

Bližší pozornost si jistě zaslouží typ dlouhých celých čísel, jedná se o celé číslo, jehož hodnota je pouze omezená velikostí dostupné paměti.

Řetězce

Řetězce jsou v Pythonu reprezentovány ve znakové sadě Unicode, proto je také vhodné v souboru uvádět jeho kódování pomocí sekvence -*- coding: <kódování> -*-, jak již jsme provedli v minulém dílu.

Řetězce zapisujeme mezi znaky ' (apostrof) nebo " (uvozovky). Pokud zapíšeme řetězec pouze takto, bude považován za sekvenci nějakých bytů bez ohledu na unicode nebo nějaké kódování, stejně jako řetězce například v C.

'Textový řětězec'
"Jiný řetězec"
'řetězec v "úvozovkách"'
"Můžem' použít i apostrof"

Také můžeme použít trojici apostrofů či uvozovek, uvozující řetězec na více řádek:

'''Tohle je řetězec
a zde pokračuje na další řádce'''
"""Druhá možnost zápisu
je tato."""

Pokud řetězec zapíšeme takto, budou jeho obsahem i přechody na nový řádek. Pokud zapíšeme řetězec do jednoduchých uvozovek a před přechod na nový řádek vložíme znak \ (podobně jako v jazyce C), tak řetězec přechody na nový řádek obsahovat nebude.

Pokud před řetězec zapsaný libovolným výše uvedeným způsobem přidáme písmeno r, potlačíme zpracování escape sekvencí v dané hodnotě. Jazyk Python používá stejné escape sekvence jako většina jiných jazyků, jejich seznam můžeme nalézt například v seriálu o C.

A stejně jako prefix r můžeme použít též písmeno u, jež označuje řetězec ve znakové sadě Unicode. Znamená to, že řetězec bude interně reprezentován ve znakové sadě Unicode, zatímco v souboru je zapsán v kódování určeném právě v tomto souboru. V řetězcích unicode, jak jsou tyto řetězce obvykle nazývány, můžeme použít ještě další escape sekvenci \u následovanou čtyřmístným kódem znaku Unicode. Python interně používá pro reprezentaci znaků pouze dva byte, a tak umí přímo pracovat pouze se znaky s kódem nižším než U+FFFF. Znaky s vyšším kódem se nám budou v Pythonu jevit jako více znaků.

Datové struktury

Python rozeznává tři základní druhy datových struktur:

  • n-tice - Jedná se o pole pevné délky i obsahu, používá se třeba při volání funkcí.
  • seznam - Pole jehož délku i obsah je možné měnit.
  • slovník (někdy též označován jako asociativní pole nebo mapa, případně hezky česky hashmapa) - mapuje hodnoty na jiné hodnoty, datový typ použitý jako index musí být neměnný, t.j. číslo, řetězec nebo výše uvedená n-tice.

Všechny tři datové struktury smějí obsahovat libovolné datové typy, kromě slovníku, jehož indexy nesmí být možné měnit.

Všechny tři tyto struktury můžeme uvést přímo v programu jako konstanty s použitím závorek:

() # prázdná n-tice

[] # prázdný seznam
{} # prázdný slovník
('a', 123, 'c')
['a', 123, 'c']
{'a':'10', 'b':'11', 'c':12}

Příště se podíváme na základní možnosti vstupu a výstupu a proměnné.

Verze pro tisk

pridej.cz

 

DISKUZE

Nejsou žádné diskuzní příspěvky u dané položky.



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