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.

031 Listen.ipynb 12KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607
  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 3: Listen und Tupel\n",
  14. "\n",
  15. "Die bisher betrachteten Datentypen umfassen stets genau einen Wert. Möchte man mehrere Werte \n",
  16. "mit den bekannten Datentypen verwalten, müsste für jeden Wert eine Variable verwendet werden.\n",
  17. "Man erkennt schnell, dass dies nicht praktikabel ist, da oft sehr viele Werte verarbeitet werden\n",
  18. "müssen und gelegentlich die genaue Anzahl vorab nicht bekannt ist."
  19. ]
  20. },
  21. {
  22. "cell_type": "markdown",
  23. "metadata": {
  24. "slideshow": {
  25. "slide_type": "slide"
  26. }
  27. },
  28. "source": [
  29. "### 3.1 Liste \n",
  30. "Python bietet mit *Listen* einen Datentyp, der\n",
  31. "* mehrere Werte\n",
  32. "* auch unterschiedlichen Typs\n",
  33. "* in einer festen Reihenfolge\n",
  34. "\n",
  35. "beinhalten kann. Listen können zudem entstehen, dynamisch wachsen, schrumpfen und aufgelöst werden, \n",
  36. "ohne dass explizit Speicherplatz angefordert oder freigegeben werden müsste. Die Speicherverwaltung übernimmt \n",
  37. "vollständig der Python-Interpreter. Listen-Literale werden in Python mit eckigen Klammern begrenzt\n",
  38. "und die Elemente mit Kommas getrennt."
  39. ]
  40. },
  41. {
  42. "cell_type": "code",
  43. "execution_count": null,
  44. "metadata": {
  45. "pycharm": {
  46. "is_executing": false,
  47. "name": "#%%\n"
  48. },
  49. "slideshow": {
  50. "slide_type": "slide"
  51. }
  52. },
  53. "outputs": [],
  54. "source": [
  55. "[3, \"Hallo\", True, None]"
  56. ]
  57. },
  58. {
  59. "cell_type": "markdown",
  60. "metadata": {},
  61. "source": [
  62. "Natürlich können Listen - wie jeder andere Datentyp - auch Variablen zugewiesen und Funktionen\n",
  63. "übergeben werden."
  64. ]
  65. },
  66. {
  67. "cell_type": "code",
  68. "execution_count": null,
  69. "metadata": {
  70. "pycharm": {
  71. "is_executing": false,
  72. "name": "#%%\n"
  73. }
  74. },
  75. "outputs": [],
  76. "source": [
  77. "a = [4, 5, 6]\n",
  78. "print(a)"
  79. ]
  80. },
  81. {
  82. "cell_type": "markdown",
  83. "metadata": {
  84. "slideshow": {
  85. "slide_type": "slide"
  86. }
  87. },
  88. "source": [
  89. "Listen-Literale werden im Code häufig erweitert, verkürzt oder hinsichtlich der Reihenfolge verändert. Um dies \n",
  90. "möglichst einfach zu gestalten, können die Listeneinträge über mehrere Zeilen verteilt werden. \n",
  91. "Ein Komma <code>,</code> nach dem letzten Eintrag ist optional erlaubt, so dass bei Anpassung nicht Syntaxfehler\n",
  92. "durch fehlende oder überzählige Kommata entstehen."
  93. ]
  94. },
  95. {
  96. "cell_type": "code",
  97. "execution_count": null,
  98. "metadata": {
  99. "pycharm": {
  100. "is_executing": false,
  101. "name": "#%%\n"
  102. }
  103. },
  104. "outputs": [],
  105. "source": [
  106. "a = [ \"Erster Eintrag\",\n",
  107. " \"Zweiter Eintrag\",\n",
  108. " # \"Letzter (?) Eintrag\",\n",
  109. " # \"Noch einer\",\n",
  110. " ]\n",
  111. "print(a)"
  112. ]
  113. },
  114. {
  115. "cell_type": "markdown",
  116. "metadata": {
  117. "pycharm": {
  118. "name": "#%% md\n"
  119. },
  120. "slideshow": {
  121. "slide_type": "slide"
  122. }
  123. },
  124. "source": [
  125. "### 3.2 Operationen \n",
  126. "\n",
  127. "Auf die einzelnen Elemente einer Liste kann mithilfe eines Index zugegriffen werden. Dabei \n",
  128. "besitzt das erste Element der Liste den Index <code>0</code>."
  129. ]
  130. },
  131. {
  132. "cell_type": "code",
  133. "execution_count": null,
  134. "metadata": {
  135. "pycharm": {
  136. "is_executing": false,
  137. "name": "#%%\n"
  138. }
  139. },
  140. "outputs": [],
  141. "source": [
  142. "liste = [1, 2, 3]\n",
  143. "print(liste[2])"
  144. ]
  145. },
  146. {
  147. "cell_type": "markdown",
  148. "metadata": {},
  149. "source": [
  150. "Der Zugriff funktioniert nicht nur lesend, sondern auch schreibend."
  151. ]
  152. },
  153. {
  154. "cell_type": "code",
  155. "execution_count": null,
  156. "metadata": {
  157. "pycharm": {
  158. "is_executing": false,
  159. "name": "#%%\n"
  160. }
  161. },
  162. "outputs": [],
  163. "source": [
  164. "liste = [1, 2, 3]\n",
  165. "liste[1] = 5\n",
  166. "print(liste)"
  167. ]
  168. },
  169. {
  170. "cell_type": "markdown",
  171. "metadata": {
  172. "slideshow": {
  173. "slide_type": "slide"
  174. }
  175. },
  176. "source": [
  177. "Erwartungsgemäß führt der Zugriff mit einem zu großen Index zu einem Laufzeitfehler."
  178. ]
  179. },
  180. {
  181. "cell_type": "code",
  182. "execution_count": null,
  183. "metadata": {
  184. "pycharm": {
  185. "is_executing": false,
  186. "name": "#%%\n"
  187. }
  188. },
  189. "outputs": [],
  190. "source": [
  191. "liste = [1, 2, 3]\n",
  192. "print(liste[10])"
  193. ]
  194. },
  195. {
  196. "cell_type": "markdown",
  197. "metadata": {
  198. "slideshow": {
  199. "slide_type": "slide"
  200. }
  201. },
  202. "source": [
  203. "Negative Zahlen werden als Zugriffsindex vom Ende der Liste interpretiert, d.h. <code>-1</code> greift auf \n",
  204. "das letzte Listenelement zu, <code>-2</code> auf das vorletzte usw."
  205. ]
  206. },
  207. {
  208. "cell_type": "code",
  209. "execution_count": null,
  210. "metadata": {
  211. "pycharm": {
  212. "is_executing": false,
  213. "name": "#%%\n"
  214. }
  215. },
  216. "outputs": [],
  217. "source": [
  218. "liste = [1, 2, 3]\n",
  219. "print(liste[-1])\n",
  220. "print(liste[-2])"
  221. ]
  222. },
  223. {
  224. "cell_type": "markdown",
  225. "metadata": {
  226. "slideshow": {
  227. "slide_type": "-"
  228. }
  229. },
  230. "source": [
  231. "Für das Aneinanderhängen zweier Listen kann die Infix-Operator <code>+</code> verwendet werden."
  232. ]
  233. },
  234. {
  235. "cell_type": "code",
  236. "execution_count": null,
  237. "metadata": {
  238. "pycharm": {
  239. "is_executing": false,
  240. "name": "#%%\n"
  241. }
  242. },
  243. "outputs": [],
  244. "source": [
  245. "[1, 2] + [3, 4]"
  246. ]
  247. },
  248. {
  249. "cell_type": "markdown",
  250. "metadata": {
  251. "slideshow": {
  252. "slide_type": "slide"
  253. }
  254. },
  255. "source": [
  256. "Dabei werden vorhandene Elemente nicht abgeglichen, d.h. ggf. sind gleiche Elemente mehrfach enthalten."
  257. ]
  258. },
  259. {
  260. "cell_type": "code",
  261. "execution_count": null,
  262. "metadata": {
  263. "pycharm": {
  264. "is_executing": false,
  265. "name": "#%%\n"
  266. }
  267. },
  268. "outputs": [],
  269. "source": [
  270. "[1, 2] + [2]\n"
  271. ]
  272. },
  273. {
  274. "cell_type": "markdown",
  275. "metadata": {
  276. "slideshow": {
  277. "slide_type": "-"
  278. }
  279. },
  280. "source": [
  281. "Für das Anhängen einzelner *Elemente* an eine Liste steht die <code>append</code> in Dot-Notation zur Verfügung."
  282. ]
  283. },
  284. {
  285. "cell_type": "code",
  286. "execution_count": null,
  287. "metadata": {
  288. "pycharm": {
  289. "is_executing": false,
  290. "name": "#%%\n"
  291. }
  292. },
  293. "outputs": [],
  294. "source": [
  295. "liste = [1, 2]\n",
  296. "liste.append(\"Wert\")\n",
  297. "print(liste)\n"
  298. ]
  299. },
  300. {
  301. "cell_type": "markdown",
  302. "metadata": {
  303. "slideshow": {
  304. "slide_type": "slide"
  305. }
  306. },
  307. "source": [
  308. "Mittels <code>remove</code> kann ein Element auch wieder aus einer Liste entfernt werden.\n",
  309. "Die nachfolgenden Elemente rücken auf, d.h. es verbleibt keine Lücke in der Liste."
  310. ]
  311. },
  312. {
  313. "cell_type": "code",
  314. "execution_count": null,
  315. "metadata": {
  316. "pycharm": {
  317. "is_executing": false,
  318. "name": "#%%\n"
  319. }
  320. },
  321. "outputs": [],
  322. "source": [
  323. "liste = [1, \"Zwei\", 3, \"Zwei\"]\n",
  324. "liste.remove(\"Zwei\")\n",
  325. "print(liste)\n",
  326. "liste.remove(\"Zwei\")\n",
  327. "print(liste)"
  328. ]
  329. },
  330. {
  331. "cell_type": "markdown",
  332. "metadata": {
  333. "slideshow": {
  334. "slide_type": "slide"
  335. }
  336. },
  337. "source": [
  338. "Ist das zu löschende Element mehrfach enthalten, wird nur das erste Auftreten entfernt."
  339. ]
  340. },
  341. {
  342. "cell_type": "code",
  343. "execution_count": null,
  344. "metadata": {
  345. "pycharm": {
  346. "is_executing": false,
  347. "name": "#%%\n"
  348. }
  349. },
  350. "outputs": [],
  351. "source": [
  352. "liste = [1, 2, 3, 2, 4]\n",
  353. "liste.remove(2)\n",
  354. "print(liste)"
  355. ]
  356. },
  357. {
  358. "cell_type": "markdown",
  359. "metadata": {
  360. "slideshow": {
  361. "slide_type": "-"
  362. }
  363. },
  364. "source": [
  365. "Möchte man ein Element an einer bestimmten Stelle einer Liste einfügen, so leistet dies <code>insert</code>. \n",
  366. "Der erste Parameter ist dabei der Index, an dem das Element eingefügt werden soll, der zweite Parameter\n",
  367. "das einzufügende Element."
  368. ]
  369. },
  370. {
  371. "cell_type": "code",
  372. "execution_count": null,
  373. "metadata": {
  374. "pycharm": {
  375. "is_executing": false,
  376. "name": "#%%\n"
  377. }
  378. },
  379. "outputs": [],
  380. "source": [
  381. "liste = ['A', 'C']\n",
  382. "liste.insert(1, 'B')\n",
  383. "print(liste)"
  384. ]
  385. },
  386. {
  387. "cell_type": "markdown",
  388. "metadata": {
  389. "slideshow": {
  390. "slide_type": "slide"
  391. }
  392. },
  393. "source": [
  394. "Die Anzahl des Auftretens eines bestimmten Elements kann mittels <code>count</code> ermittelt werden."
  395. ]
  396. },
  397. {
  398. "cell_type": "code",
  399. "execution_count": null,
  400. "metadata": {
  401. "pycharm": {
  402. "is_executing": false,
  403. "name": "#%%\n"
  404. }
  405. },
  406. "outputs": [],
  407. "source": [
  408. "liste = ['A', 'C', 'A', 'B']\n",
  409. "liste.count('Z')"
  410. ]
  411. },
  412. {
  413. "cell_type": "markdown",
  414. "metadata": {
  415. "slideshow": {
  416. "slide_type": "-"
  417. }
  418. },
  419. "source": [
  420. "Die Position eines Elements in einer Liste liefert <code>index</code>."
  421. ]
  422. },
  423. {
  424. "cell_type": "code",
  425. "execution_count": null,
  426. "metadata": {
  427. "pycharm": {
  428. "is_executing": false,
  429. "name": "#%%\n"
  430. }
  431. },
  432. "outputs": [],
  433. "source": [
  434. "liste = ['A', 'C', 'A', 'B']\n",
  435. "liste.index('B')"
  436. ]
  437. },
  438. {
  439. "cell_type": "markdown",
  440. "metadata": {
  441. "slideshow": {
  442. "slide_type": "slide"
  443. }
  444. },
  445. "source": [
  446. "Ob ein Element überhaupt in einer Liste enthalten ist, kann mit dem Infix-Operator <code>in</code>\n",
  447. "festgestellt werden."
  448. ]
  449. },
  450. {
  451. "cell_type": "code",
  452. "execution_count": null,
  453. "metadata": {
  454. "pycharm": {
  455. "is_executing": false,
  456. "name": "#%%\n"
  457. }
  458. },
  459. "outputs": [],
  460. "source": [
  461. "liste = ['A', 'C', 'A', 'B']\n",
  462. "'P' in liste"
  463. ]
  464. },
  465. {
  466. "cell_type": "markdown",
  467. "metadata": {
  468. "slideshow": {
  469. "slide_type": "slide"
  470. }
  471. },
  472. "source": [
  473. "### 3.3 Built-In-Funktionen und Listen\n",
  474. "\n",
  475. "Wird der Built-In-Funktion <code>len</code> eine Liste als Parameter übergeben, so ist das \n",
  476. "Ergebnis die Anzahl der in der Liste enthaltenen Elemente."
  477. ]
  478. },
  479. {
  480. "cell_type": "code",
  481. "execution_count": null,
  482. "metadata": {
  483. "pycharm": {
  484. "is_executing": false,
  485. "name": "#%%\n"
  486. }
  487. },
  488. "outputs": [],
  489. "source": [
  490. "liste = ['A', 'B', 'C']\n",
  491. "len(liste)"
  492. ]
  493. },
  494. {
  495. "cell_type": "markdown",
  496. "metadata": {
  497. "slideshow": {
  498. "slide_type": "slide"
  499. }
  500. },
  501. "source": [
  502. "Die Built-In-Funktionen <code>min</code> und <code>max</code> ergeben das Minimum bzw. das Maximum der Liste."
  503. ]
  504. },
  505. {
  506. "cell_type": "code",
  507. "execution_count": null,
  508. "metadata": {
  509. "pycharm": {
  510. "is_executing": false,
  511. "name": "#%%\n"
  512. }
  513. },
  514. "outputs": [],
  515. "source": [
  516. "liste = ['AA', 'B', 'a']\n",
  517. "print(min(liste))\n",
  518. "print(max(liste))"
  519. ]
  520. },
  521. {
  522. "cell_type": "markdown",
  523. "metadata": {
  524. "slideshow": {
  525. "slide_type": "slide"
  526. }
  527. },
  528. "source": [
  529. "Natürlich müssen dazu die Elemente der Liste vergleichbar sein, d.h. eine Ordnungsrelation definiert sein."
  530. ]
  531. },
  532. {
  533. "cell_type": "code",
  534. "execution_count": null,
  535. "metadata": {
  536. "pycharm": {
  537. "is_executing": false,
  538. "name": "#%%\n"
  539. }
  540. },
  541. "outputs": [],
  542. "source": [
  543. "liste = ['A', 2, 'C']\n",
  544. "print(min(liste))"
  545. ]
  546. },
  547. {
  548. "cell_type": "markdown",
  549. "metadata": {
  550. "slideshow": {
  551. "slide_type": "slide"
  552. }
  553. },
  554. "source": [
  555. "Und schließlich: mit der Built-In Funktion <code>del</code> können Elemente einer Liste \n",
  556. "mit Angabe ihrer Position gelöscht werden."
  557. ]
  558. },
  559. {
  560. "cell_type": "code",
  561. "execution_count": null,
  562. "metadata": {
  563. "pycharm": {
  564. "is_executing": false,
  565. "name": "#%%\n"
  566. }
  567. },
  568. "outputs": [],
  569. "source": [
  570. "liste = ['A', 2, 'C', 2]\n",
  571. "del(liste[1], liste[2])\n",
  572. "print(liste)\n"
  573. ]
  574. }
  575. ],
  576. "metadata": {
  577. "celltoolbar": "Slideshow",
  578. "kernelspec": {
  579. "display_name": "Python 3 (ipykernel)",
  580. "language": "python",
  581. "name": "python3"
  582. },
  583. "language_info": {
  584. "codemirror_mode": {
  585. "name": "ipython",
  586. "version": 3
  587. },
  588. "file_extension": ".py",
  589. "mimetype": "text/x-python",
  590. "name": "python",
  591. "nbconvert_exporter": "python",
  592. "pygments_lexer": "ipython3",
  593. "version": "3.9.9"
  594. },
  595. "pycharm": {
  596. "stem_cell": {
  597. "cell_type": "raw",
  598. "metadata": {
  599. "collapsed": false
  600. },
  601. "source": []
  602. }
  603. }
  604. },
  605. "nbformat": 4,
  606. "nbformat_minor": 1
  607. }