Unterschiede
Hier werden die Unterschiede zwischen zwei Versionen der Seite angezeigt.
Beide Seiten, vorherige Überarbeitung Vorherige Überarbeitung Nächste Überarbeitung | Vorherige Überarbeitung | ||
talit:tutorial_oop3 [2025-05-12 12:30] – [Auswahl eines Wortes] hof | talit:tutorial_oop3 [2025-05-26 14:11] (aktuell) – [Aufgabe F] hof | ||
---|---|---|---|
Zeile 294: | Zeile 294: | ||
Du hast damit das [[wp> | Du hast damit das [[wp> | ||
- | |||
### Aufgabe D: Wie lange lernen? | ### Aufgabe D: Wie lange lernen? | ||
Ähnlich wie die Entscheidung über das nächste Wortpaar möchten wir auch die Entscheidung, | Ähnlich wie die Entscheidung über das nächste Wortpaar möchten wir auch die Entscheidung, | ||
Zeile 304: | Zeile 303: | ||
* `CountingCriterion`: | * `CountingCriterion`: | ||
* `OrCriterion`: | * `OrCriterion`: | ||
+ | |||
+ | {{: | ||
Wie sieht die `ConsoleLearner.learn` Methode jetzt aus? | Wie sieht die `ConsoleLearner.learn` Methode jetzt aus? | ||
+ | ## Speichern & Lesen | ||
+ | Wir möchten `VocabularyUnits` in eine Datei speichern und von dort wieder lesen können. Es bietet sich an, eine Unit als JSON-Objekt zu speichern. JSON (JavaScript Object Notation) sind Dictionaries, | ||
+ | |||
+ | <code python> | ||
+ | {" | ||
+ | </ | ||
+ | |||
+ | Eine ganze Unit wäre dann eine Liste solcher Objekte: | ||
+ | |||
+ | <code python> | ||
+ | [ | ||
+ | { | ||
+ | " | ||
+ | " | ||
+ | " | ||
+ | " | ||
+ | " | ||
+ | }, | ||
+ | { | ||
+ | " | ||
+ | " | ||
+ | " | ||
+ | " | ||
+ | " | ||
+ | } | ||
+ | ] | ||
+ | </ | ||
+ | ### Aufgabe E: JSON-Serialisierung | ||
+ | |||
+ | * Füge eine Methode `to_dict(self)` zu `WordPair` hinzu, die ein Wort-Paar und seine Stats in ein Dictionary verwandelt und zurückgibt. | ||
+ | * Füge eine Methode `save_to(self, | ||
+ | |||
+ | <code python> | ||
+ | def save_to(self, | ||
+ | json_list = [pair.to_dict() for pair in self.pairs] | ||
+ | import json | ||
+ | with open(filename, | ||
+ | json.dump(json_list, | ||
+ | </ | ||
+ | |||
+ | |||
+ | ### Statische Methoden | ||
+ | Fürs Einlesen kommt die umgekehrte `json.load` Funktion zum Einsatz. Allerdings haben wir noch ein kleines Problem: Eine VocabularyUnit existiert ja noch gar nicht, wenn wir sie einlesen wollen aus der Datei. Wir benötigen also eine Funktion, die nicht an eine bestimmte Unit gebunden ist. Diese werden mit `@staticmethod` annotiert und haben keinen `self` Parameter. Statische Funktionen werden direkt über den Klassennamen aufgerufen. | ||
+ | |||
+ | <code python> | ||
+ | class WordPair: | ||
+ | ... | ||
+ | | ||
+ | @staticmethod | ||
+ | def from_dict(data): | ||
+ | """ | ||
+ | pair = WordPair(data[' | ||
+ | # TODO also read stats if available | ||
+ | |||
+ | |||
+ | class VocabularyUnit: | ||
+ | ... | ||
+ | | ||
+ | @staticmethod | ||
+ | def read_from(filename): | ||
+ | """ | ||
+ | import json | ||
+ | pairs = [] | ||
+ | with open(filename, | ||
+ | json_pairs = json.load(infile) | ||
+ | pairs = [WordPair.from_dict(p) for p in json_pairs] | ||
+ | return VocabularyUnit(pairs) | ||
+ | </ | ||
+ | ### Aufgabe F | ||
+ | Füge statische Methoden zu `VocabularyUnit` und `WordPair` hinzu, um die gespeicherten Daten wieder einlesen zu können. | ||
+ | |||
+ | Ein Beispielprogramm für unseren Code könnte nun so aussehen: | ||
+ | |||
+ | <code python> | ||
+ | from voci import * | ||
+ | |||
+ | filename = ' | ||
+ | unit = VocabularyUnit.read_from(filename) | ||
+ | |||
+ | learner = ConsoleLearner() | ||
+ | try: | ||
+ | learner.learn(unit) | ||
+ | unit.print_stats() | ||
+ | finally: | ||
+ | unit.save_to(filename) | ||
+ | </ | ||
+ | |||
+ | |||
+ | ### Aufgabe G - Webapp | ||
+ | S. auch [[talit: |