You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

062 Dictionaries.ipynb 6.9KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332
  1. {
  2. "cells": [
  3. {
  4. "cell_type": "markdown",
  5. "metadata": {
  6. "slideshow": {
  7. "slide_type": "slide"
  8. }
  9. },
  10. "source": [
  11. "# Software Entwicklung \n",
  12. "\n",
  13. "## Kapitel 6: Mengen und Dictionaries"
  14. ]
  15. },
  16. {
  17. "cell_type": "markdown",
  18. "metadata": {
  19. "slideshow": {
  20. "slide_type": "slide"
  21. }
  22. },
  23. "source": [
  24. "### 6.2 Dictionaries\n",
  25. "\n",
  26. "Die bereits behandelten *Listen* sind bekanntlich eine Möglichkeit, beliebige\n",
  27. "Werte mit Hilfe eines numerischen Zugriffsschlüssels, dem Index, zu verwalten.\n",
  28. "Die Werte besitzen bei Listen damit eine Reihenfolge, d.h. mathematisch gesehen ist eine\n",
  29. "Liste eine Abbildung $f$ von ganzzahligen Indexwerten auf eine beliebige Wertemenge $W$:\n",
  30. "\n",
  31. "$$f: N_0 \\rightarrow W$$\n",
  32. "\n",
  33. "\n",
  34. "Dictionaries sind nun eine weitere Möglichkeit, beliebige Werte zu verwalten. Allerdings\n",
  35. "verzichtet man auf die Reihenfolge zugunsten auch nicht-numerischer\n",
  36. "Zugriffsschlüssel aus einer Schlüsselmenge $D$:\n",
  37. "\n",
  38. "$$f: D \\rightarrow W$$"
  39. ]
  40. },
  41. {
  42. "cell_type": "markdown",
  43. "metadata": {
  44. "slideshow": {
  45. "slide_type": "slide"
  46. }
  47. },
  48. "source": [
  49. "Im Gegensatz zu Listen, die mit eckigen Klammern (<code>[</code> und <code>]</code>) eingefasst\n",
  50. "wurden, werden Dictionaries mit geschweiften Klammern (<code>{</code> und <code>}</code>) notiert.\n",
  51. "\n",
  52. "Da sich der Zugriffsschlüssel nicht mehr aus der Reihenfolge ergibt, muss er explizit angegeben\n",
  53. "werden. Man spricht hier von *key*-*value* Paaren. In Python werden die Paare mit einem Doppelpunkt\n",
  54. "getrennt, wobei *key* vor, und *value* nach dem Doppelpunkt angegeben wird.\n",
  55. "\n",
  56. "<code> \\< key \\> : \\< value \\> </code>\n"
  57. ]
  58. },
  59. {
  60. "cell_type": "code",
  61. "execution_count": null,
  62. "metadata": {
  63. "pycharm": {
  64. "name": "#%%\n"
  65. }
  66. },
  67. "outputs": [],
  68. "source": [
  69. "dict = { \"BMEI\" : \"Bachelor Medizintechnik Vertiefung EI\",\n",
  70. " \"BMMF\" : \"Bachelor Medizintechnik Vertiefung MF\",\n",
  71. " 17 : \"Hallo\",\n",
  72. " True : \"Wahr\"}"
  73. ]
  74. },
  75. {
  76. "cell_type": "markdown",
  77. "metadata": {
  78. "slideshow": {
  79. "slide_type": "slide"
  80. }
  81. },
  82. "source": [
  83. "Der Zugriff auf die Elemente des Dictionaries erfolgt - wie auch bei der Liste - durch\n",
  84. "Angabe des Zugriffsschlüssels in eckigen Klammern."
  85. ]
  86. },
  87. {
  88. "cell_type": "code",
  89. "execution_count": null,
  90. "metadata": {
  91. "pycharm": {
  92. "name": "#%%\n"
  93. }
  94. },
  95. "outputs": [],
  96. "source": [
  97. "print(dict[True])"
  98. ]
  99. },
  100. {
  101. "cell_type": "markdown",
  102. "metadata": {
  103. "pycharm": {
  104. "name": "#%% md\n"
  105. },
  106. "slideshow": {
  107. "slide_type": "slide"
  108. }
  109. },
  110. "source": [
  111. "Als Schlüssel sind nur unveränderliche Datentypen erlaubt. Listen oder Mengen sind\n",
  112. "demnach keine zulässigen Schlüssel."
  113. ]
  114. },
  115. {
  116. "cell_type": "markdown",
  117. "metadata": {},
  118. "source": [
  119. "Der <code>in</code>-Operator überprüft bei einem Dictionary, ob der angefragte Wert als\n",
  120. "*Schlüssel* im Dictionary enthalten ist."
  121. ]
  122. },
  123. {
  124. "cell_type": "code",
  125. "execution_count": null,
  126. "metadata": {
  127. "pycharm": {
  128. "name": "#%%\n"
  129. }
  130. },
  131. "outputs": [],
  132. "source": [
  133. "if \"BMEI\" in dict:\n",
  134. " print(\"Als Schlüssel enthalten\")\n",
  135. "if \"Bachelor Medizintechnik Vertiefung MF\" in dict:\n",
  136. " print(\"Die Werte werden nicht durchsucht, daher sollte dieser Text nicht erscheinen\")\n"
  137. ]
  138. },
  139. {
  140. "cell_type": "markdown",
  141. "metadata": {
  142. "pycharm": {
  143. "name": "#%% md\n"
  144. },
  145. "slideshow": {
  146. "slide_type": "slide"
  147. }
  148. },
  149. "source": [
  150. "Mittels\n",
  151. "\n",
  152. "* <code>keys</code> kann eine Liste der Schlüssel\n",
  153. "* <code>values</code> kann eine Liste der Werte\n",
  154. "* <code>items</code> kann eine Liste von *key*-*value*-Tupeln\n",
  155. "\n",
  156. "extrahiert werden."
  157. ]
  158. },
  159. {
  160. "cell_type": "code",
  161. "execution_count": null,
  162. "metadata": {
  163. "pycharm": {
  164. "name": "#%%\n"
  165. },
  166. "slideshow": {
  167. "slide_type": "subslide"
  168. }
  169. },
  170. "outputs": [],
  171. "source": [
  172. "print(list(dict.keys()))\n",
  173. "print(list(dict.values()))\n",
  174. "print(list(dict.items()))\n",
  175. " "
  176. ]
  177. },
  178. {
  179. "cell_type": "markdown",
  180. "metadata": {
  181. "pycharm": {
  182. "name": "#%% md\n"
  183. },
  184. "slideshow": {
  185. "slide_type": "slide"
  186. }
  187. },
  188. "source": [
  189. "Beim Iterieren über ein Dictionary wird die Schlüsselmenge durchlaufen."
  190. ]
  191. },
  192. {
  193. "cell_type": "code",
  194. "execution_count": null,
  195. "metadata": {
  196. "pycharm": {
  197. "name": "#%%\n"
  198. }
  199. },
  200. "outputs": [],
  201. "source": [
  202. "for element in dict:\n",
  203. " print(element)"
  204. ]
  205. },
  206. {
  207. "cell_type": "markdown",
  208. "metadata": {
  209. "pycharm": {
  210. "name": "#%% md\n"
  211. },
  212. "slideshow": {
  213. "slide_type": "slide"
  214. }
  215. },
  216. "source": [
  217. "Der Zugriff auf die Werte kann dann über den Schlüssel erfolgen."
  218. ]
  219. },
  220. {
  221. "cell_type": "code",
  222. "execution_count": null,
  223. "metadata": {
  224. "pycharm": {
  225. "name": "#%%\n"
  226. }
  227. },
  228. "outputs": [],
  229. "source": [
  230. "for element in dict:\n",
  231. " print(dict[element])"
  232. ]
  233. },
  234. {
  235. "cell_type": "markdown",
  236. "metadata": {
  237. "slideshow": {
  238. "slide_type": "slide"
  239. }
  240. },
  241. "source": [
  242. "Oder man iteriert gleich über die Wertemenge."
  243. ]
  244. },
  245. {
  246. "cell_type": "code",
  247. "execution_count": null,
  248. "metadata": {
  249. "pycharm": {
  250. "name": "#%%\n"
  251. }
  252. },
  253. "outputs": [],
  254. "source": [
  255. "for wert in dict.values():\n",
  256. " print(wert)"
  257. ]
  258. },
  259. {
  260. "cell_type": "markdown",
  261. "metadata": {
  262. "slideshow": {
  263. "slide_type": "slide"
  264. }
  265. },
  266. "source": [
  267. "Das Löschen eines Eintrags in einem Dictionary erfolgt mit <code>del</code>."
  268. ]
  269. },
  270. {
  271. "cell_type": "code",
  272. "execution_count": null,
  273. "metadata": {
  274. "pycharm": {
  275. "name": "#%%\n"
  276. }
  277. },
  278. "outputs": [],
  279. "source": [
  280. "del(dict[\"BMEI\"])\n",
  281. "print(dict)"
  282. ]
  283. },
  284. {
  285. "cell_type": "markdown",
  286. "metadata": {
  287. "slideshow": {
  288. "slide_type": "slide"
  289. }
  290. },
  291. "source": [
  292. "Das gesamte Dictionary wird mit <code>clear</code> geleert."
  293. ]
  294. },
  295. {
  296. "cell_type": "code",
  297. "execution_count": null,
  298. "metadata": {
  299. "pycharm": {
  300. "name": "#%%\n"
  301. }
  302. },
  303. "outputs": [],
  304. "source": [
  305. "dict.clear()\n",
  306. "print(dict)"
  307. ]
  308. }
  309. ],
  310. "metadata": {
  311. "celltoolbar": "Slideshow",
  312. "kernelspec": {
  313. "display_name": "Python 3 (ipykernel)",
  314. "language": "python",
  315. "name": "python3"
  316. },
  317. "language_info": {
  318. "codemirror_mode": {
  319. "name": "ipython",
  320. "version": 3
  321. },
  322. "file_extension": ".py",
  323. "mimetype": "text/x-python",
  324. "name": "python",
  325. "nbconvert_exporter": "python",
  326. "pygments_lexer": "ipython3",
  327. "version": "3.9.9"
  328. }
  329. },
  330. "nbformat": 4,
  331. "nbformat_minor": 1
  332. }