Vorschlag für einen Merge-Algorithmus für den Excel-Upload von Prüfungsleistungen, der auch mit separaten Uploads mehrerer Prüfer klar kommt
Go to file
Wolfgang Wiedermann 2e4b7174a9
Create pylint.yml
2023-01-25 15:57:47 +01:00
.github/workflows Create pylint.yml 2023-01-25 15:57:47 +01:00
.gitignore Ausgabetexte des Übernahmeprotokolls nachgebessert, Algorithmus im Bereich bereits gesetzter Werte nachgebessert 2023-01-25 13:23:56 +01:00
database.db Ausgabetexte des Übernahmeprotokolls nachgebessert, Algorithmus im Bereich bereits gesetzter Werte nachgebessert 2023-01-25 13:23:56 +01:00
excel_file_1.xlsx Ausgangszustand Beispiel 2023-01-25 10:00:02 +01:00
excel_file_2.xlsx Das mit dem Beispielcode hat sich rentiert, das Testen macht sichtbar, wo noch konzeptionelle Schwächen sind. 2023-01-25 10:58:13 +01:00
merge_sample.py Ausgabetexte des Übernahmeprotokolls nachgebessert, Algorithmus im Bereich bereits gesetzter Werte nachgebessert 2023-01-25 13:23:56 +01:00
README.md Beschreibungstext hinzugefügt 2023-01-25 15:56:27 +01:00

Vorschlag: Zusammenführen statt Überschreiben im Excel-Upload für Prüfungsergebnisse

In diesem Repository beschreiben wir einen Vorschlag zur konsistenten und nutzerfreundlichen Verarbeitung mehrerer sequenziell ausgeführter Uploads von Excel-Dateien mit Noten zu einer Prüfung.

Das Verfahren soll sicherstellen, dass auch dann, wenn mehrere Prüfer einer gemeinsamen Prüfung unabhängig voneinander Leistungen via Excel-Import bereitstellen, keine bereits eingetragenen Noten gelöscht werden.

Der Hintergrund ist, dass insb. bei großen Prüfungsgruppen die Korrekturarbeit zwischen mehreren Prüfern aufgeteilt werden soll, ohne dass die Studierenden vorher bereits in Gruppen, die dem Prüfer eindeutig zugeordnet sind, aufgeteilt werden sollen.

Jeder der Prüfer soll jedoch trotzdem zur Noteneintragung selbständig und unabhängig von seinen KollegInnen mit dem Excel-Upload arbeiten können.

Anmerkung:

Der beiliegende Beispielcode dient zum Testen und zur Kommunikation des Algorithmus und ist ohne konkrete Beziehung zu Datenstrukturen und Code von HISinOne umgesetzt.

Algorithmus:

Grundannahme

Der gesamte Vorgang zum Import einer Excel-Datei wird in einer Transaktion abgehandelt, sodass die Datei entweder vollständig übernommen wird, oder in der Datenbank/HISinOne der Zustand von vor dem Import wiederhergestellt wird.

Ablauf

für alle Zeilen im Tabellenblatt:
  prüfe ob Prüfungsanmeldesatz vorhanden:
    nein: 
      Eintrag in Fehlerliste (die angezeigt wird!) erzeugen
  prüfe ob bereits eine Note gesetzt:
    ja: 
      wenn Note gültig 
        ja: 
          wenn Note verändert:
            ja: 
              Nutzerinteraktion: neuen Wert übernehmen oder alten behalten
            nein: 
              ignorieren bzw. ggf. Meldung in sichtbarem Protokoll
        nein: 
          Eintrag in Fehlerliste (die angezeigt wird!) erzeugen
    nein: 
      Wert setzen
      ggf. in GUI sichtbarer Protokolleintrag