DatenSammeln.py 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. # (c) Hochschule Anhalt, veröffentlicht unter MIT-Lizenz
  2. # Datensammler
  3. # Autor: Viktor Lysow, Johannes Tümler
  4. # Letzte Änderung: 22.04.2022
  5. # Zweck: Daten für den Matlab Beleg sammeln
  6. # Der Nachfolgende Codeblock "BLOCK1" sorgt dafür, dass man aus jeder Datei heraus das Hauptprogramm starten kann.
  7. # Dadurch kann man in jeder Datei auf "play" drücken und es wird automatisch main.py gestartet.
  8. if __name__=="__main__":
  9. import subprocess
  10. # Auf Linux oder Mac aktivieren Sie die folgende Zeile und deaktivieren Sie die Zeile danach:
  11. #subprocess.call("python3 main.py", shell=True) # die richtige Main-Datei aufrufen (unser eigentliches Hauptprogramm)
  12. subprocess.call("main.py", shell=True) # die richtige Main-Datei aufrufen (unser eigentliches Hauptprogramm)
  13. exit(0) # nun das Programm hier beenden .. wir wollen ja nur das Hauptprogramm starten und nicht *diese* Datei.
  14. # Ende "BLOCK1"
  15. import datetime
  16. dateiName = 'Spiel_Daten.csv'
  17. """
  18. Erläuterung zum Daten Sammeln:
  19. [0] = Jahr
  20. [1] = Monat
  21. [2] = Tag
  22. [3] = Stunde
  23. [4] = Minute
  24. [5] = Sekunde
  25. [6] = Schritte Held
  26. [7] = Schüsse Held
  27. [8] = Zeit Level 1
  28. [9] = Zeit Level 2
  29. ###ALT[10] = Zeit Level 3
  30. [10] = Gesamt Zeit
  31. [11] = Besiegt in Level
  32. """
  33. # ['0','Datum','Uhrzeit','Schritte Held', 'Schüsse Held´', 'Zeit Level 1', 'Zeit Level2', 'Zeit Level3', 'Gesamt Zeit', 'Besiegt in Level']
  34. neue_zeile = [0,0,0,0,0,0,0,0,0,0,0,0] # Zeile, die eingefügt wird
  35. def open_csv():
  36. try: # Test, ob die csv existiert
  37. op_text = open(dateiName)
  38. except: # Wenn nicht, neu erstellen
  39. neu_text = open(dateiName, 'w')
  40. #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]}')
  41. neu_text.close()
  42. op_text = open(dateiName)
  43. text = op_text.read()
  44. op_text.close()
  45. zeilen = text.split('\n')
  46. tabelle = []
  47. if not zeilen == ['']:
  48. for i in range(len(zeilen)):
  49. spalten = zeilen[i].split(',')
  50. tabelle.append(spalten)
  51. return tabelle
  52. def daten_csv(spalte,
  53. info): # (welche Spalte, die Information in der Spalte) Zeit, Schritte und Schüsse werden hier übergeben
  54. info = str(info)
  55. neue_zeile[spalte] = info
  56. def write_csv(): # Die csv wird hier überschrieben (Speichern)
  57. neue_zeile[0] = datetime.datetime.today().year # Datum in Spalte 1 - 3
  58. neue_zeile[1] = datetime.datetime.today().month
  59. neue_zeile[2] = datetime.datetime.today().day
  60. neue_zeile[3] = datetime.datetime.today().hour # Uhrzeit in Spalte 3 - 6
  61. neue_zeile[4] = datetime.datetime.today().minute
  62. neue_zeile[5] = datetime.datetime.today().second
  63. tabelle = open_csv() # Gesamte Tabelle
  64. tabelle.append(neue_zeile) # Gesmate Tabelle + der neuen Zeile
  65. neu_text = open(dateiName, 'w')
  66. for i in range(len(tabelle)):
  67. neu_text.write(
  68. 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]}')
  69. if not len(tabelle) - 1 == i:
  70. neu_text.write('\n')
  71. neu_text.close()
  72. reset()
  73. def reset(): # neue Zeile wird wieder auf 0 gesetzt für das eventuelle nächste Spiel
  74. global neue_zeile
  75. neue_zeile = [0,0,0,0,0,0,0,0,0,0,0,0]