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
| |
|
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
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 ...
|