Első lépések Pythonban, ismerkedés a változókkal

Ebben a notebookban rövid példákon keresztül megismerkedünk a Python nyelv szintaxisával, és néhány alapvető adattípussal és adatstruktúrával. Később ezeket és az ezekből származtatott adatstruktúrákat fogjuk lépten-nyomon használni.


Megjegyzések (Comment-ek)

A Pythonban a megjegyzések kettőskereszttel ('#') kezdődnek, és a sor végéig tartanak. Egy megjegyzés lehet sor elején, vagy követhet szóközt, tabulátor karaktert, de ha egy karakterlánc (string) belsejébe teszed, az nem lesz megjegyzés (lásd a példában!). A kettőskereszt karakter egy karakterláncon belül csak egy kettőskeresztet jelent.


In [1]:
# ez az első megjegyzés
SPAM = 1                 # ez a második megjegyzés
                         # ... és ez a harmadik.
STRING = "# Ez nem megjegyzés, mert idézőjelekben van."

A komment csak a programozónak szól emlékeztetőül, vagy más programozók megértését segíti. Noha gyakran elmarad, a kódok rendszeres dokumentálása megjegyzésekkel később (amikor már a kód részleteit a feledés homálya borítja) nagyon kifizetődő lehet.


A Python használata számológépként

A notebookot lehet úgy használni, mint egy sima számológépet: be lehet írni egy kifejezést, és az kiszámolja az értékét. A kifejezések nyelvtana a szokásos: a +, -, * és / műveletek ugyanúgy működnek, mint a legtöbb nyelvben (például Fortran vagy C). A zárójeleket értelemszerűen az elvégzendő műveletek csoportosítására, a műveleti sorrend meghatározására használjuk. Például:


In [2]:
2 + 2


Out[2]:
4

In [3]:
50 - 5*6


Out[3]:
20

In [4]:
(50 - 5*6) / 4


Out[4]:
5.0

In [5]:
8 / 5  # az osztás egész számok esetén is lebegőpontos eredményt ad.


Out[5]:
1.6

Az egész számok (pl. 2, 4, 20) alkotják az int típust, a valós számok (pl 5.0, 1.6) pedig a float típust. A Python 3-ban az osztás (/) mindig lebegőpontos értékeket ad vissza. Lefelé kerekítő egészosztás elvégzéséhez, amellyel egész értéket kapunk, a // operátor használható; az osztás maradékához a %-t hívhatjuk segítségül:


In [6]:
17 / 3  # hagyományos osztás lebegőpontos eredménnyel


Out[6]:
5.666666666666667

In [7]:
17 // 3  # az egészosztással megszabadulunk a törtrésztől


Out[7]:
5

In [8]:
17 % 3  # a % operátor az osztás maradékával tér vissza


Out[8]:
2

In [9]:
5 * 3 + 2  # eredmény * osztó + maradék


Out[9]:
17

A Pythonban a ** operátor használható a hatvány kiszámítására:


In [10]:
5 ** 2  # 5 négyzete


Out[10]:
25

In [11]:
2 ** 7  # 2 7-dik hatványa


Out[11]:
128

A Python a lebegőpontos számokat bizonyos tekintetben előnyben részesíti az egész számokhoz képest. Azok a műveletek, amelyeknél keverednek a típusok, az egészeket lebegőpontossá alakítják:


In [12]:
3 * 3.75 / 1.5


Out[12]:
7.5

In [13]:
7.0 / 2


Out[13]:
3.5

Előfordul néha, hogy egyes függvények int típusú változót, várnak és ezt egy float típusúból kell előállítanunk. A típusok közti konverziót az int() és float() függvények segítségével tehetjük meg.


In [14]:
int(3.1415)


Out[14]:
3

In [15]:
float(42)


Out[15]:
42.0

A Python komplex számokat is tud kezelni – a képzetes részt a j vagy J jellel képezhetjük. A komplex számot (valós+képzetes j) formában írhatjuk:


In [16]:
1j * 1J


Out[16]:
(-1+0j)

In [17]:
3+1j*3


Out[17]:
(3+3j)

In [18]:
(3+1j)*3


Out[18]:
(9+3j)

In [19]:
(1+2j)/(1+1j)


Out[19]:
(1.5+0.5j)

A komplex számokat gyakran két lebegőpontos számmal ábrázolják: a képzetes és a valós résszel. A z komplex számnak ezeket a részeit talán kicsit szokatlan módon (a változó után írt . és a megfelelő szó ) a z.real és z.imag utasításokkal olvashatjuk vissza.


In [20]:
(1.5+0.5j).real


Out[20]:
1.5

In [21]:
(1.5+0.5j).imag


Out[21]:
0.5

A lebegőpontos és egész típusú konverziós függvények (float() és int()) nem működnek komplex számokra. A komplex-valós átalakításnak több lehetséges módja is van: ahhoz, hogy egy komplex számból valósat csinálj, használd az abs(z) utasítást, hogy megkapd a nagyságát, vagy a fennt már megismert z.real és z.imag utasítást, ha a valós része vagy a képzetes része kell.


In [22]:
float(3.0+4.0j) # ez nem működik


---------------------------------------------------------------------------
TypeError                                 Traceback (most recent call last)
<ipython-input-22-c2200350f3cd> in <module>()
----> 1 float(3.0+4.0j) # ez nem működik

TypeError: can't convert complex to float

In [ ]:
abs(3.0+4.0j)  # sqrt(a.real**2 + a.imag**2)

Változók

Programozási feladatok során rendszerint változókban tároljuk a hasznos információkat. A megírt programok nem konkrét számértékekre hanem, változókra hivatkoznak, ez teszi lehetővé, hogy különböző bemeneti adatokra ugyanazt az algoritmust ha kell, többször is lefuttathassuk. A változók neveit rendszerint az angol ABC betűiből és esetleg néhány egyéb karakterből szokás összeállítani. Például:

szelesseg        # ebben csak betűk vannak
a_folyoso_hossza # ebben a változó névben szerepel a _ karakter is

A változók neveit célszerű úgy megválasztani hogy később könnyen kitalálható legyen, mit is jelölünk vele. A legtöbb programozási nyelvhez hasonlóan az egyenlőségjellel (=) lehet értéket adni egy változónak. Az értékadás után az értelmező újabb utasításra vár, látszólag nem történik semmi:


In [23]:
szelesseg = 20
magassag = 5*9

A háttérben viszont létrejöttek a szelesseg és magassag változók, amikkel most már hasznos dolgokat tudunk művelni. Számítsuk ki például a két változó szorzatát:


In [24]:
szelesseg * magassag


Out[24]:
900

Ha egy változó nincs definiálva (nincs érték rendelve hozzá), és használni próbáljuk, akkor hibaüzenetet kapunk:


In [25]:
n  # Az n változót még nem definiáltuk


---------------------------------------------------------------------------
NameError                                 Traceback (most recent call last)
<ipython-input-25-a2ede96a8cec> in <module>()
----> 1 n  # Az n változót még nem definiáltuk

NameError: name 'n' is not defined

Az utoljára kiírt kifejezés értéke a _ (alsóvonás) változóban van. Így ha a Pythont asztali számológépként használod, akkor egyszerűbb folytatni a számolásokat, például:


In [26]:
ado = 12.5 / 100

In [27]:
ar = 100.50

In [28]:
ar * ado


Out[28]:
12.5625

In [29]:
ar + _


Out[29]:
113.0625

In [30]:
round(_, 2) #kerekítés 2 tizedes jegyre


Out[30]:
113.06

Ezt a változót csak olvasható változóként kezelhetjük. Ne adjunk értéket neki, mert ha adunk, akkor létrehozunk egy független helyi változót azonos névvel, amely meggátolja a beépített változó elérését, amely mágikus módon viselkedik. (Ha egy globális változó nevével létrehozunk egy helyi változót, akkor az értelmező a helyit használja.)

A notebookban az előző eredményen kívül jóval korábbi eredményekre is hivatkozhatunk. Például 2. parancs kimenetére a következőképpen:


In [31]:
Out[2]


Out[31]:
4

Logikai Bool-változók és feltételes végrehajtás

Ahhoz, hogy a program reagálni tudjon bemenetekre, vagy egy már kiszámolt részeredménytől függhessen további működése, szükség van feltételek vizsgálatára. Gondoljunk például a másodfokú egyenlet megoldóképletére! Attól függően, hogy a diszkrimináns pozitív vagy negatív, léteznek, ill. nem léteznek valós gyökök, így értelemszerűen egy ilyen programnak "döntenie" kell. A döntés egy feltétel vizsgálatán alapul (pl. poz. vagy neg. diszkrimináns), ami lehet igaz, vagy hamis, angolul True, ill. False. Az igaz és hamis értéket tárolni képes változó típusa: boolean (Bool-változó). (Emlékezzünk vissza az int ill. float típusokra).

Két objektum azonosságáról dupla egyenlőségjellel, azaz a == operátor segítségével tájékozódhatunk.


In [32]:
1 == 1  # 1 megeggyezik 1-el ?


Out[32]:
True

In [33]:
1 == 2 # 1 megeggyezik 2-vel ?


Out[33]:
False

Ha arról akarunk meggyőződni hogy két objektum nem ugyanaz, akkor ezt a != operátor segítségével tehetjük meg:


In [34]:
1!=2 #1 nem 2 ?


Out[34]:
True

Természetszerűen számok esetén a <,> operátorok segítségével dönthetjük el, hogy melyik szám a nagyobb:


In [35]:
1>2


Out[35]:
False

In [36]:
1<2


Out[36]:
True

In [37]:
1j+3>2 # complex számokra nem értelmezzük a <> jeleket!!


---------------------------------------------------------------------------
TypeError                                 Traceback (most recent call last)
<ipython-input-37-b892698ccb2f> in <module>()
----> 1 1j+3>2 # complex számokra nem értelmezzük a <> jeleket!!

TypeError: unorderable types: complex() > int()

Egy igaz/hamis értéket változóban is tárolhatunk:


In [38]:
igazvagyhamis= 2*2==5

In [39]:
igazvagyhamis


Out[39]:
False

Az is és is not relációk összehasonlítják, hogy két dolog valóban azonos-e. Minden összehasonlító relációnak azonos precedenciája van, mely magasabb, mint a számokkal végzett műveleteké.


In [40]:
1==1.0 # A számegyenesen történő összehasonlítás


Out[40]:
True

In [41]:
1 is 1.0 # Objektum típusa és értéke szerint történő összehasonlítás: int vs float


Out[41]:
False

Egy objektumról az isinstance parancs segítségével tudjuk eldönteni, hogy milyen típusú:


In [42]:
isinstance(1,int) # Vajon az '1' az int típusú ?


Out[42]:
True

In [43]:
isinstance(2,float) # Vajon a '2' float típusú ?


Out[43]:
False

Relációkat láncolhatunk is, például: az a < b == c megvizsgálja, hogy az a kisebb-e mint b, és ezen felül b egyenlő-e c-vel.


In [44]:
b=2
1 < 2 == b


Out[44]:
True

In [45]:
b=3
1 < 2 == b


Out[45]:
False

A relációkat összefűzhetjük and és or logikai műveletekkel is. Reláció erdményét (vagy bármely logikai műveletét) ellentettjére változtathatjuk a not művelettel.


In [46]:
not 2*2==5


Out[46]:
True

Az and, or és not fügvények, ha zárójelezést nem alkalmazunk, akkor a relációjelek után kerülnek kiértékelésre (más szóval mondva a relációjelekhez képest alacsonyabb a precedenciájuk). A három logikai művelet közül a not értékelődik ki legelőször (neki a magasabb a precedenciája a másik kettőhöz képest), és az or értékelődik ki utolsónak.

Tehát az A and not B or C ugyanazt jelenti, mint az (A and (not B)) or C. Természetesen a zárójeleket használhatjuk a kívánt feltétel eléréséhez.


In [47]:
b=3
((1==2) and (3==4)) or (b==3)


Out[47]:
True

Karakterláncok (Stringek)

A számok mellett a Python karakterláncokkal, például szavakkal is tud műveleteket végezni. A karakterláncokat egyszeres ('...') vagy dupla idézőjelek ("...") közé lehet zárni. A két jelölés között nincs jelentős különbség. A \ használható arra, hogy a karakterláncbeli idézőjeleket levédjük:


In [48]:
'spam eggs'


Out[48]:
'spam eggs'

In [49]:
'doesn\'t'


Out[49]:
"doesn't"

In [50]:
"doesn't"


Out[50]:
"doesn't"

In [51]:
'"Yes," he said.'


Out[51]:
'"Yes," he said.'

In [52]:
"\"Yes,\" he said."


Out[52]:
'"Yes," he said.'

In [53]:
'"Isn\'t," she said.'


Out[53]:
'"Isn\'t," she said.'

A kimeneti karakterlánc idézőjelekben jelenik meg, a speciális karakterek vissza-perrel (\) levédve. Bár ez néha különbözőnek látszik a bemenettől (az idézőjel fajtája megváltozhat), a két karakterlánc egyenértékű. A print() függvény egy sokkal olvashatóbb kimenetet eredményez, elhagyva az idézőjeleket és kiírva a levédett és speciális karaktereket:


In [54]:
print('"Isn\'t," she said.')


"Isn't," she said.

In [55]:
s = 'First line.\nSecond line.'  # \n újsort jelent

In [56]:
s  # print() nélkül a \n benne van a kimenetben


Out[56]:
'First line.\nSecond line.'

In [57]:
print(s)  # print()-tel az \n újsort hoz létre


First line.
Second line.

Ha nem akarod, hogy a \ jellel kezdődő karakterek speciális karakterként értelmeződjenek, akkor nyers karakterláncokat használhatsz egy r-et helyezve a kezdő idézőjel elé:


In [58]:
print('C:\some\name')  # \n újsort jelent


C:\some
ame

In [59]:
print(r'C:\some\name')  # r van az idézőjel előtt


C:\some\name

A literális karakterláncok többsorosak is lehetnek. Egy lehetőség erre a hármas idézőjelek használata: """...""" vagy '''...'''. Ilyenkor az újsorok automatikusan belekerülnek a karakterláncba, de ez a viselkedés megszüntethető, ha a sor végére egy \-t adsz. A következő példa


In [60]:
print("""\
Usage: thingy [OPTIONS]
     -h                        Display this usage message
     -H hostname               Hostname to connect to
""")


Usage: thingy [OPTIONS]
     -h                        Display this usage message
     -H hostname               Hostname to connect to

Karakterláncokat a + művelettel ragaszthatunk össze, és *-gal ismételhetünk.


In [61]:
3 * 'un' + 'ium'


Out[61]:
'unununium'

Két egymást követő literális karakterláncot (azokat, amik idézőjelben vannak, és nem egy változóban, vagy nem egy függvény hoz létre) az értelmező magától összefűz:


In [62]:
'Py' 'thon'


Out[62]:
'Python'

De ez csak két literálissal működik, változóval vagy kifejezéssel nem:


In [63]:
prefix = 'Py'
prefix 'thon'  # nem tud változót és literális karakterláncot összefűzni


  File "<ipython-input-63-28f030133dcf>", line 2
    prefix 'thon'  # nem tud változót és literális karakterláncot összefűzni
                ^
SyntaxError: invalid syntax

Ha változókat akarsz összefűzni, vagy változót literálissal, használj + műveletet:


In [64]:
prefix = 'Py'
prefix + 'thon'


Out[64]:
'Python'

A literálisok összefűzése különösen hasznos hosszú sorok széttörésére:


In [65]:
text = ('Több karakterláncot írhatunk zárójelbe, '
            'hogy összefűzhessük azokat.')
text


Out[65]:
'Több karakterláncot írhatunk zárójelbe, hogy összefűzhessük azokat.'

Minden karakterhez a karakterláncban a Python rendel egy sorszámot (indexet). Az első karakterhez tartozik a 0 index, a következőhöz az 1-es index és így tovább. (Ez a konvenció tükrözi a C-ben megszokottakat.)


In [66]:
szo = 'Python'

In [67]:
szo[0]  # karakter a 0 pozícióban


Out[67]:
'P'

In [68]:
szo[5]  # karakter a 5 pozícióban


Out[68]:
'n'

Az indexek negatívak is lehetnek, ilyenkor jobbról kezdünk el számolni:


In [69]:
szo[-1]  # utolsó karakter


Out[69]:
'n'

In [70]:
szo[-2]  # utolsó előtti karakter


Out[70]:
'o'

In [71]:
szo[-6]


Out[71]:
'P'

Az indexelésen felül a szeletelés is támogatott. Míg az indexelés egyetlen karaktert jelöl ki, a szeletelés egy részkarakterláncot:


In [72]:
szo[0:2]  # karakterek a 0 pozíciótól (benne van) a 2-esig (az már nem)


Out[72]:
'Py'

In [73]:
szo[2:5]  # karakterek a 2 pozíciótól (benne van) a 5-esig (az már nem)


Out[73]:
'tho'

A kezdő index mindig beleértendő az eredménybe, a végső index pedig nem. Ez teszi lehetővé, hogy s[:i] + s[i:] mindig egyenlő s-el:


In [74]:
szo[:2] + szo[2:]


Out[74]:
'Python'

In [75]:
szo[:4] + szo[4:]


Out[75]:
'Python'

A szeletek indexeinek hasznos alapértékei vannak; a kihagyott első index alapértéke 0, az elhagyott második index alapértéke a szeletelendő karakterlánc hossza:


In [76]:
szo[:2]  # karakterek az elejétől a 2-esig (már nincs benne)


Out[76]:
'Py'

In [77]:
szo[4:]  # karekterek a 4-es pozíciótól (benne van) a végéig


Out[77]:
'on'

In [78]:
szo[-2:] # karakterek az utolsó előttitől (beleértve) a végéig


Out[78]:
'on'

Jegyezd meg, hogy a -0 valóban azonos a 0-val, így ez nem jobbról számol!


In [79]:
szo[-0]     # mivel -0 és 0 egyenlőek


Out[79]:
'P'

A nem negatív indexek esetén a szelet hossza az indexek különbségével egyenlő, ha mindkettő a valódi szóhatárokon belül van. Például a szo[1:3] hossza 2. Ha olyan indexet használunk, amely túl nagy, az eredmény hibát ad:


In [80]:
szo[42]  # a szo csak 7 karakteres


---------------------------------------------------------------------------
IndexError                                Traceback (most recent call last)
<ipython-input-80-8ad9d484d8f7> in <module>()
----> 1 szo[42]  # a szo csak 7 karakteres

IndexError: string index out of range

A Python karakterláncait nem lehet megváltoztatni, azok megváltoztathatatlanok. Ezért, ha egy adott indexű helyhez értéket rendelünk, hibát kapunk:


In [81]:
szo[0] = 'J'


---------------------------------------------------------------------------
TypeError                                 Traceback (most recent call last)
<ipython-input-81-3d63625a841c> in <module>()
----> 1 szo[0] = 'J'

TypeError: 'str' object does not support item assignment

Ha másik karakterláncra van szükség, alkothatunk egy újat:


In [82]:
'J' + szo[1:]


Out[82]:
'Jython'

In [83]:
szo[:2] + 'py'


Out[83]:
'Pypy'

A beépített len() függvény a karakterlánc hosszával tér vissza:


In [84]:
s = 'legeslegelkáposztásíthatatlanságoskodásaitokért'
len(s)


Out[84]:
47

Listák (List)

A Python többfajta összetett adattípust ismer, amellyel több különböző értéket csoportosíthatunk. Egy igen sokoldalú összetett adattípus a lista, amelyet vesszőkkel elválasztott értékekként írhatunk be szögletes zárójelbe zárva. Az alábbiakban a listákkal kapcsolatos műveletek alapjait tekintjük át. Listákról magyarul itt egy kicsit bővebben olvashattok. A lista elemeinek nem kell azonos típusúaknak lenniük, bár sok alkalmazásban minden elem azonos típusú.


In [85]:
a = ['spam', 'tojások', 100, 1234]
a
['spam', 'tojások', 100, 1234]


Out[85]:
['spam', 'tojások', 100, 1234]

Ahogy a karakterláncokat, a listákat is indexelhetjük és szeletelhetjük:


In [86]:
a[0]


Out[86]:
'spam'

In [87]:
a[3]


Out[87]:
1234

In [88]:
a[-2]


Out[88]:
100

In [89]:
a[1:-1]   # a szeletelés új listát ad


Out[89]:
['tojások', 100]

A listák az összefűzést is támogatják:


In [90]:
a[:2] + ['sonka', 2*2]


Out[90]:
['spam', 'tojások', 'sonka', 4]

In [91]:
3*a[:3] + ['Boe!']


Out[91]:
['spam',
 'tojások',
 100,
 'spam',
 'tojások',
 100,
 'spam',
 'tojások',
 100,
 'Boe!']

A karakterláncokkal ellentétben – amelyek megváltoztathatatlanok – a listák egyes elemeit módosíthatjuk:


In [92]:
a[2] = a[2] + 23
a


Out[92]:
['spam', 'tojások', 123, 1234]

A szeleteknek értékeket is adhatunk, és ez akár a lista elemszámát is megváltoztathatja:


In [93]:
a[0:2] = [1, 12] # Pár elem átírása:
a


Out[93]:
[1, 12, 123, 1234]

In [94]:
a[0:2] = [] # Pár elem törlése:
a


Out[94]:
[123, 1234]

In [95]:
a[1:1] = ['bletch', 'xyzzy'] # Pár elem beszúrása:
a


Out[95]:
[123, 'bletch', 'xyzzy', 1234]

In [96]:
a[:0] = a     # Beszúrja magát (pontosabban egy másolatát) a saját elejére.
a


Out[96]:
[123, 'bletch', 'xyzzy', 1234, 123, 'bletch', 'xyzzy', 1234]

A beépített len() függvény listákra is alkalmazható:


In [97]:
len(a)


Out[97]:
8

A listák egymásba ágyazhatóak, azaz listába elhelyezhetünk listát elemként:


In [98]:
a = ['a', 'b', 'c']
n = [1, 2, 3]
x = [a, n]
x


Out[98]:
[['a', 'b', 'c'], [1, 2, 3]]

In [99]:
x[0]


Out[99]:
['a', 'b', 'c']

In [100]:
x[0][1]


Out[100]:
'b'

In [101]:
x[0][1]


Out[101]:
'b'

Előfordul hogy meg szeretnénk tudni, hogy egy adott elem hanyadik helyen van a listában ezt az .index() függvény alkalmazásával kaphatjuk meg. Például nézzük meg hogy a lent definiált autok lista hanyadik eleme a 'merci' karakter:


In [102]:
autok=['skoda','vw','merci','mazda']

In [103]:
autok.index('merci')


Out[103]:
2

Mint ahogy azt láttuk, a karakterláncok is indexelhetőek. Karakterláncban szereplő karakterek indexére is rákérdezhetünk az .index() paranccsal:


In [104]:
betuk='abcdef'

In [105]:
betuk.index('e')


Out[105]:
4

Még egy hasznos adatstruktúra: Szótárak (Dict-ek)

Sokszor előfordul, hogy adatokat nem valamilyen sorrendben, hanem inkább valamilyen címke szerint szeretnénk tárolni. Tipikus példája ennek egy idegen nyelvű szótár, ahol egy magyar kifejezést egy más nyelvbeli kifejezéssel párosítunk. Ezeknél a struktúráknál sokszor nem lényeges a sorrend, gondoljunk itt például valamilyen tárgy tulajdonságaira. Legyen mondjuk egy autónk ami

  • piros színű
  • 1976-ban gyártották
  • 3m hosszú
  • aok621 rendszámú

Ezek a tulajdonságok egyértelműen meghatározzák az autót attól függetlenül, hogy a felsorolást milyen sorrendben tettük. Ilyen jellegű adatstruktúra a Python nyelvben a szótár vagy angolul a dictionary, röviden dict. A szótárak létrehozása kulcsszavak és a hozzájuk rendelt érték segítségével az alábbi szintaxis alapján történik:


In [106]:
tel = {'János': 4098, 'Simon': 4139}
tel


Out[106]:
{'János': 4098, 'Simon': 4139}

A listákkal ellenben, ahol sorszám alapján hivatkozunk egy elemre, itt kulcsszó alapján:


In [107]:
tel['János']


Out[107]:
4098

Új elemet is kulcsszó alapján adhatunk egy dict-hez:


In [108]:
tel['Géza'] = 4127
tel


Out[108]:
{'Géza': 4127, 'János': 4098, 'Simon': 4139}

Természetesen nem csak számokat adhatunk meg a szótárunkba mint hozzárendelt értéket:


In [109]:
tel['Brünhilda']='NEM TUDOM A SZÁMÁT'
tel


Out[109]:
{'Brünhilda': 'NEM TUDOM A SZÁMÁT', 'Géza': 4127, 'János': 4098, 'Simon': 4139}

Így törlünk valakit a telefonkönyvből:


In [110]:
del tel['Simon']
tel


Out[110]:
{'Brünhilda': 'NEM TUDOM A SZÁMÁT', 'Géza': 4127, 'János': 4098}

A dict-ben szereplő kulcsszavakat a ".keys()" metódus alkalmazásával tudjuk elérni.


In [111]:
tel.keys()


Out[111]:
dict_keys(['Géza', 'Brünhilda', 'János'])

A fenti parancs kimenete látszólag tartalmazza az általunk kért információt. Sokszor azonban célszerű ezt az outputot a list() parancs segítségével listává konvertálni:


In [112]:
list(tel.keys())


Out[112]:
['Géza', 'Brünhilda', 'János']

Vajon Géza benne van a telefonkönyvben? Ezt a listáknál megismert "in" parancsal tudjuk ellenőrizni:


In [113]:
'Géza' in tel


Out[113]:
True

Megjegyzés: Nyilván attól, mert Brünhilda benne van a telefonkönyvben, nem biztos, hogy tudjuk a telefonszámát:


In [114]:
'Brünhilda' in tel


Out[114]:
True

In [115]:
tel['Brünhilda']


Out[115]:
'NEM TUDOM A SZÁMÁT'

A dict függvény segítségével az alábbi módon is definiálhatunk szótárakat:


In [116]:
tel2=dict(Ica=1234,Maca=4321,Dada=5567)
tel2


Out[116]:
{'Dada': 5567, 'Ica': 1234, 'Maca': 4321}

Bool változók és más változók kapcsolata

Ahogy fentebb láttuk, egy objektumot egész számmá (int() függvény) vagy lebegőpontos számmá tudunk konvertálni ( float() függvény), illetve láttunk példát arra is hogy listává konvertáljunk valamit. Objektumokat Bool-változóvá is tudunk konvertálni. Erre szolgál a bool() függvény. Alább néhány példát nézzünk meg, hogy bizonyos dolgok hogy konvertálódnak a bool() függvénnyel.

Egy szám vagy egy karakterlánc True értéket ad:


In [117]:
bool(1.0)


Out[117]:
True

In [118]:
bool('szoveg')


Out[118]:
True

Hasonlóan True értéked ad, ha egy nem üres listát vagy általában egy más létező objektumot vizsgálunk:


In [119]:
bool([1,'Bela'])


Out[119]:
True

False értéket ad a 0 az üres karakterlánc, illetve az üres lista:


In [120]:
bool(0)


Out[120]:
False

In [121]:
bool(0.0)


Out[121]:
False

In [122]:
bool('')


Out[122]:
False

In [123]:
bool([])


Out[123]:
False

Egy látszólag rosszul működő példa:


In [124]:
'a' == ('a' or 'b')


Out[124]:
True

In [125]:
'b' == ('a' or 'b')


Out[125]:
False

In [126]:
'a' == ('a' and 'b')


Out[126]:
False

In [127]:
'b' == ('a' and 'b')


Out[127]:
True

A második példa vajon miért False, ha az első True ? A harmadik miért False, ha a látszólag hasonló negyedik True? Ezen a ponton úgy tűnhet, hogy az and és or utasítások nem működnek megfelelően! Ha részletesen kiböngésszük, hogy mit is csinál a Python-értelmező, akkor kiderül, hogy pontosan azt teszi, amire megkértük. DE ez nem pontosan az, amire elsőnek gondolnánk! Az első két példa tehát nem azt ellenőrzi, hogy a == előtt álló karakter az szerepel-e a zárójelben. Mi is történik pontosan? Amikor a Python egy or kifejezéssel találkozik (a zárójeleken belül), sorba megy az or kifejezés által kapcsolatba hozott elemeken, és az első True-ként kiértékelhető objektum értékét adja vissza, tehát nem True vagy False-t hanem a változó értékét. Ez azért van így, mert ha egy or kifejezés egyik tagja igaz, akkor az egész kifejezés igaz. Az and ezzel szemben addig lépdel végig az alkotó kifejezéseken, amíg meggyőződött róla, hogy mindegyik kifejezés igaznak számít, és a legutolsó értéket adja vissza. A bool operációk ezen viselkedését rövid zár-nak hívják, és sok programozási nyelvben hasonlóan működik. Tehát ha arról akarunk meggyőződni, hogy egy kifejezés valamely kifejezéscsoport egyikével megegyezik, akkor az alábbiak szerint szükséges eljárni:


In [128]:
(('a' == 'a') or ('a' == 'b'))


Out[128]:
True

In [129]:
(('b' == 'a') or ('b' == 'b'))


Out[129]:
True

Előfordul azonban sokszor, hogy az a csoport, amihez egy lehetséges elemet össze kell hasonlítani, igen népes. Például hogy mondjuk meg, hogy egy karakterlánc szerepel egy adott hosszú listában? Erre alkalmazható az in kulcsszó:


In [130]:
Tage_der_Woche=['Montag','Dienstag','Mittwoch','Donnerstag','Freitag','Samstag','Sonntag']

In [131]:
'hetfo' in Tage_der_Woche


Out[131]:
False

In [132]:
'Montag' in Tage_der_Woche


Out[132]:
True