12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697 |
- # (c) Hochschule Anhalt, veröffentlicht unter MIT-Lizenz
- # Datensammler
- # Autor: Viktor Lysow, Johannes Tümler
- # Letzte Änderung: 22.04.2022
- # Zweck: Daten für den Matlab Beleg sammeln
- # Der Nachfolgende Codeblock "BLOCK1" sorgt dafür, dass man aus jeder Datei heraus das Hauptprogramm starten kann.
- # Dadurch kann man in jeder Datei auf "play" drücken und es wird automatisch main.py gestartet.
- if __name__=="__main__":
- import subprocess
- # Auf Linux oder Mac aktivieren Sie die folgende Zeile und deaktivieren Sie die Zeile danach:
- #subprocess.call("python3 main.py", shell=True) # die richtige Main-Datei aufrufen (unser eigentliches Hauptprogramm)
- subprocess.call("main.py", shell=True) # die richtige Main-Datei aufrufen (unser eigentliches Hauptprogramm)
- exit(0) # nun das Programm hier beenden .. wir wollen ja nur das Hauptprogramm starten und nicht *diese* Datei.
- # Ende "BLOCK1"
- import datetime
- dateiName = 'Spiel_Daten.csv'
- """
- Erläuterung zum Daten Sammeln:
- [0] = Jahr
- [1] = Monat
- [2] = Tag
- [3] = Stunde
- [4] = Minute
- [5] = Sekunde
- [6] = Schritte Held
- [7] = Schüsse Held
- [8] = Anzahl der Monster in Level 1
- [9] = Anzahl der Monster in Level 2
- [10] = Schüsse Prinzessin
- [11] = Besiegt in Level (Spezial: level 3 ist Spielsieg)
- """
- neue_zeile = [0,0,0,0,0,0,0,0,0,0,0,0] # Zeile, die eingefügt wird
- def open_csv():
- try: # Test, ob die csv existiert
- op_text = open(dateiName)
- except: # Wenn nicht, neu erstellen
- neu_text = open(dateiName, 'w')
- #neu_text.write(f'{zeile0[0]},{zeile0[1]},{zeile0[2]},{zeile0[3]},{zeile0[4]},{zeile0[5]},{zeile0[6]},{zeile0[7]},{zeile0[8]},{zeile0[9]},{zeile0[10]},{zeile0[11]}')
- neu_text.close()
- op_text = open(dateiName)
- text = op_text.read()
- op_text.close()
- zeilen = text.split('\n')
- tabelle = []
- if not zeilen == ['']:
- for i in range(len(zeilen)):
- spalten = zeilen[i].split(',')
- tabelle.append(spalten)
- return tabelle
- def daten_csv(spalte,info): # (welche Spalte, die Information in der Spalte) Zeit, Schritte und Schüsse werden hier übergeben
- info = str(info)
- neue_zeile[spalte] = info
- def write_csv(): # Die csv wird hier überschrieben (Speichern)
- neue_zeile[0] = datetime.datetime.today().year # Datum in Spalte 1 - 3
- neue_zeile[1] = datetime.datetime.today().month
- neue_zeile[2] = datetime.datetime.today().day
- neue_zeile[3] = datetime.datetime.today().hour # Uhrzeit in Spalte 3 - 6
- neue_zeile[4] = datetime.datetime.today().minute
- neue_zeile[5] = datetime.datetime.today().second
- tabelle = open_csv() # Gesamte Tabelle
- tabelle.append(neue_zeile) # Gesmate Tabelle + der neuen Zeile
- neu_text = open(dateiName, 'w')
- for i in range(len(tabelle)):
- neu_text.write(
- f'{tabelle[i][0]},{tabelle[i][1]},{tabelle[i][2]},{tabelle[i][3]},{tabelle[i][4]},{tabelle[i][5]},{tabelle[i][6]},{tabelle[i][7]},{tabelle[i][8]},{tabelle[i][9]},{tabelle[i][10]},{tabelle[i][11]}')
- if not len(tabelle) - 1 == i:
- neu_text.write('\n')
- neu_text.close()
- reset()
- def reset(): # neue Zeile wird wieder auf 0 gesetzt für das eventuelle nächste Spiel
- global neue_zeile
- neue_zeile = [0,0,0,0,0,0,0,0,0,0,0,0]
|