lehrkraefte:sbt:informatik:glf22:python:little-programming-tasks

Differences

This shows you the differences between two versions of the page.

Link to this comparison view

Both sides previous revision Previous revision
Next revision
Previous revision
lehrkraefte:sbt:informatik:glf22:python:little-programming-tasks [2022/12/09 08:35]
Karlheinz Schubert
lehrkraefte:sbt:informatik:glf22:python:little-programming-tasks [2022/12/09 22:45] (current)
Karlheinz Schubert
Line 24: Line 24:
 <hidden Hinweis3> <hidden Hinweis3>
 <code python> <code python>
-c_unicode ord("c"+abc ['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 
-C_unicode = ord("C"+       'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z']
-print("Unicode von 'c' ="c_unicode) +
-print("Unicode von 'C="C_unicode)+
  
-character_65 chr(65+shift int(input("Offset: ")
-character_100 chr(220) + 
-print("Unicode 65 steht für", character_65+while True: 
-print("Unicode 100 steht für", character_100) +    quelltext input("Quelltext: ") 
-# ausserhalb des englischen Alphabeths+    if len(quelltext) == 0: 
-Ue_unicode ord("Ü"+        break 
-print("Unicode von 'Ü' =", Ue_unicode+    code = "" 
-character_220 chr(220+    for buchstabe in quelltext
-print("Unicode 220 steht für", character_220)+        index abc.index(buchstabe
 +        indexCode = index + shift 
 +        # if indexCode > len(abc) - 1: 
 +        #     indexCode -len(abc
 +        indexCode indexCode % len(abc
 +        code += abc[indexCode] 
 +    print(code)
 </code> </code>
 </hidden> </hidden>
- 
- 
 ---- ----
 <hidden Expertenaufgabe> <hidden Expertenaufgabe>
Line 59: Line 61:
   * Ergänze das Programm so, dass du nach dem Dateinamen gefragt wirst und beliebig viele Dateien nacheinander verschlüsseln kannst.   * Ergänze das Programm so, dass du nach dem Dateinamen gefragt wirst und beliebig viele Dateien nacheinander verschlüsseln kannst.
 </hidden> </hidden>
 +<hidden Hinweis3>
 +  * Möglichkeit zur Verschlüsselung von beliebigen UniCode Zeichen
 +<code python>
 +c_unicode = ord("c")
 +C_unicode = ord("C")
 +print("Unicode von 'c' =", c_unicode)
 +print("Unicode von 'C' =", C_unicode)
  
 +character_65 = chr(65) 
 +character_100 = chr(220) 
 +print("Unicode 65 steht für", character_65) 
 +print("Unicode 100 steht für", character_100) 
 +# ausserhalb des englischen Alphabeths: 
 +Ue_unicode = ord("Ü"
 +print("Unicode von 'Ü' =", Ue_unicode) 
 +character_220 = chr(220) 
 +print("Unicode 220 steht für", character_220) 
 +</code> 
 +</hidden>
 </WRAP> </WRAP>
  
Line 67: Line 86:
 <WRAP center round todo> <WRAP center round todo>
 Wenn du nach einigen Prüfungen Noten hast und einen bestimmten Durchschnitt erreichen möchtest, dann kannst du die ganz leicht ausrechnen (lassen), welche Note du als nächstes schreiben musst. Wenn du nach einigen Prüfungen Noten hast und einen bestimmten Durchschnitt erreichen möchtest, dann kannst du die ganz leicht ausrechnen (lassen), welche Note du als nächstes schreiben musst.
 +  - Schreibe ein Programm, dass deine bisherigen Noten in einem Feld enthält, dich nach dem gewünschten Durchschnitt fragt und dann die Mindesnote ausgibt, die du im nächsten Test erreichen solltest. 
 +  - Verbessere das Programm so, dass du zusätzlich eingeben kannst, wieviele Tests noch anstehen, also wie viele Noten du noch bekommen kannst.
 +
 +<hidden Hinweis1>
 +<code python>
 +while True:
 +    Eingabe = input('Gewünschter Schnitt: ')
 +    if len(Eingabe) == 0:
 +        break
 +    # Umwandlung der Texteingabe in eine Dezimalzahl:
 +    WunschNote = float(Eingabe)
 +</code>
 +</hidden>
 +
 +<hidden Hinweis2>
 +<code python>
 +Noten = [4.5, 5, 3.75, 5.5]
 +Durchschnitt_ungerundet = sum(Noten)/len(Noten)
 +Durchschnitt = round(sum(Noten)/len(Noten), 2)
 +</code>
 +</hidden>
 +</WRAP>
 +
 +===== Vokabeltrainer =====
      
-* (a) Schreibe ein Programmdass deine bisherigen Noten in einem Feld enthältdich nach dem gewünschten Durchschnitt fragt und dann die Mindesnote ausgibt+<WRAP center round todo> 
 +  - Lege eine Liste mit Vokabeln an: 
 +    <code python> 
 +    Vokabeln = [ 
 +       "lesen","read" 
 +       "Apfel","apple", 
 +       "geben","give" 
 +    ] 
 +    </code> 
 +     
 +Die Vokabeln sind in Paaren hintereinander eingetragen.
  
-* (b) Verbessere das Programm so, dass du zusätzlich eingeben kannst, wieviele Tests noch anstehen, also wie viele Noten du noch bekommen kannst.+  - Frage alle Variablen der Reihe nach ab und kontrolliere, ob die Antwort richtig war. 
 +  - Erweitere das Programm um einen Abragemodus: a) Abfrage wie unter 1. und b) Zufallsabrage. Beende dies Programm wenn du eine leere Antwort eingibst. 
 +  - Ergänze eine Hilfefunktion: Gibst du als Anwort ein '?' ein, so wird die die richtige Antwort zur Frage angezeigt.
  
 +<hidden Hinweis1>
 +Da die Variablen in Paaren angeordnet sind, müssen die Indizees vielfache von zwei sein: Die abgefragte Variable 2n+0 und die Antwort 2n+1.
 +</hidden>
 +<hidden Hinweis2>
 +<code python>
 +Antwort = input(f'Übersetze "{Vokabel}": ')
 +</code>
 +</hidden>
 +----
 +<hidden Expertenaufgabe1>
 +  * Baue das Programm so um, dass du die Übersetzungsrichtung wählen kannst.
 +</hidden>
 +<hidden Expertenaufgabe2>
 +  * Erweitere das Programm so, dass du auswertest, wie viel richtige und falsche Antworten du gegeben hast. 
 +</hidden>
 +<hidden Expertenaufgabe2>
 +  * Erweitere das Programm so, dass du es für mehr als zwei Sprachen verwenden kannst. 
 +</hidden>
 +<hidden Lösung>
 +<code python>
 +"""
 +Vokabeltrainer
 +"""
 +from random import randint
 +
 +Vokabeln = [
 +    'lesen', 'read',
 +    'Apfel', 'apple',
 +    'geben', 'give',
 +    'lächeln', 'smile',
 +    'rennen', 'run'
 +]
 +Richtige = []
 +Zaehler_richtig = 0
 +Zaehler_falsch = 0
 +while True:
 +    Mode = input('de - Deutsch -> Englisch\ned - Englisch -> Deutsch: ')
 +    if Mode == 'ed' or Mode == 'de':
 +        break
 +    print('Unbekannter Mode, versuche es noch einmal!')
 +
 +while True:
 +    index = randint(0, len(Vokabeln)//2 - 1)
 +    #print(f'{index} of {len(Vokabeln)//2 - 1}')
 +    if index in Richtige:
 +        if len(Richtige)==len(Vokabeln)//2:
 +            break
 +        continue
 +    deutsch = Vokabeln[2*index]
 +    englisch = Vokabeln[2*index+1]
 +    if Mode == 'de':
 +        Frage = deutsch
 +        Antwort = englisch
 +    else:
 +        Frage = englisch
 +        Antwort = deutsch
 +    Test = input(f'Übersetze "{Frage}" ▶ ')
 +    if len(Test) == 0:
 +        break
 +    if Antwort == Test:
 +        print('richtig')
 +        Zaehler_richtig += 1
 +        Richtige.append(index)
 +    else:
 +        print('falsch')
 +        Zaehler_falsch += 1
 +
 +print(f'Du hattest {Zaehler_richtig} richtige und {Zaehler_falsch} falsche {"Antwort" if Zaehler_falsch==1 else "Antworten"}.')
 +print('fertig')
 +
 +</code>
 +</hidden>
 </WRAP> </WRAP>
  • lehrkraefte/sbt/informatik/glf22/python/little-programming-tasks.1670571342.txt.gz
  • Last modified: 2022/12/09 08:35
  • by Karlheinz Schubert