Compare commits

..

3 Commits

Author SHA1 Message Date
63f9e40fc6 Resultater fra xml og live mtr 2022-05-21 16:27:59 +02:00
7abb532b90 Lagde funksjon for mtr spooling 2022-05-21 16:27:15 +02:00
66ce00d496 La til xml påmeldingsimport igjen 2022-05-21 16:25:50 +02:00
3 changed files with 84 additions and 15 deletions

25
dev.py
View File

@ -1,16 +1,25 @@
import otime
import mtr
from rich import print
from rich import inspect
from rich.console import Console
from rich.columns import Columns
from rich.table import Table
if __name__ == "__main__":
event = otime.Event(0, 'supercup')
event.import_ttime_cnf('k2ds/tt.cnf')
event.import_ttime_db('k2ds/db.csv')
event.import_mtr_file('k2ds/mtr.txt')
#card_punches = otime.card_punch.list_from_mtr_f('sc_2021_ttime/mtr.csv')
event.match_runners_cards()
event.create_start_list_pdf('starttimes.pdf')
#event.get_xml_res().write('Resultater.xml')
event = otime.Event(0, 'Jukola-testløp')
#event.import_ttime_cnf('k2ds/tt.cnf')
#event.import_ttime_db('k2ds/db.csv')
#event.import_mtr_file('k2ds/mtr.txt')
#card_punches = otime.card_punch.list_from_mtr_f('sc_2021_ttime/mtr.csv')
#event.match_runners_cards()
#event.create_start_list_pdf('starttimes.pdf')
#event.get_xml_res().write('Resultater.xml')
event.import_ttime_cnf('/home/trygve/Dokumenter/Jukola_uttak/tt.cnf')
event.runners = otime.runners_from_xml_entries('/home/trygve/Dokumenter/Jukola_uttak/entries_Nattøkt,_Jukola-testløp.xml', event.o_classes)
event.card_dumps = mtr.dump_all('/dev/ttyUSB0')
event.match_runners_cards()
event.get_xml_res().write('Resultater_uttak.xml')
for n in event.card_dumps:
print(n.card, n.controls)

19
mtr.py Normal file
View File

@ -0,0 +1,19 @@
import otime
import serial
from time import sleep
def dump_all(port):
mtr = serial.Serial(port, baudrate=9600, timeout=40)
# dump all command
mtr.write(b'/SA')
card_dumps = []
sleep(0.4)
while mtr.in_waiting > 0:
mtr.read_until(expected=b'\xFF\xFF\xFF\xFF')
size = mtr.read(size=1)
if size == b'\xe6':
meat = mtr.read(229)
full = b'\xFF\xFF\xFF\xFF' + size + meat
card_r = otime.CardDump.from_mtr_bytes(full)
card_dumps.append(card_r)
return card_dumps

View File

@ -43,7 +43,7 @@ class Event:
self.runners = runnerarray
def import_mtr_file(self, mtr_file):
self.card_dumps = card_punch.list_from_mtr_f(mtr_file)
self.card_dumps = CardDump.list_from_mtr_f(mtr_file)
def match_runners_cards(self):
for n in self.runners:
@ -89,7 +89,7 @@ class Event:
# </Person>
# <Organisation>
org = ET.SubElement(person_result, 'Organisation')
xml_child(org, 'Id', '0')
xml_child(org, 'Id', n.club_id)
xml_child(org, 'Name', n.club)
country = ET.SubElement(org, 'Country')
# TODO: hent land fra løperobjektet
@ -138,7 +138,7 @@ class Event:
def create_start_list_pdf(self, file_name):
pdf = FPDF()
pdf.add_page()
pdf.add_font("DejaVuSans", fname="/usr/share/fonts/dejavu-sans-fonts/DejaVuSans.ttf")
pdf.add_font("DejaVuSans", fname="/usr/share/fonts/truetype/DejaVuSans.ttf")
pdf.set_font("DejaVuSans", size=10)
line_height = pdf.font_size * 2
col_width = pdf.epw / 4 # distribute content evenly
@ -153,14 +153,14 @@ class Event:
pdf.ln(line_height)
pdf.output(file_name)
# The runner object stores all the data specific to a runner.
class Runner:
def __init__(self, runner_id, first, last, club, country, card, o_class, start_time):
def __init__(self, runner_id, first, last, club, club_id, country, card, o_class, start_time):
self.id = runner_id
self.first = first
self.last = last
self.club = club
self.club_id = club_id
self.country = country
self.card = card
self.o_class = o_class
@ -199,12 +199,16 @@ class Runner:
else:
runner_o_class = None
# TODO: Gjør sånn at den lager nye o klasser om den ikke finnes fra før
options = tt_line[5].split(',')
try:
club_id = options[options.index('A')+3]
except:
club_id = 0
try:
options = tt_line[5].split(',')
start_time = options[options.index('U')+1]
except:
start_time = None
return Runner(eventorid, first, last, club, country, card, runner_o_class, start_time)
return Runner(eventorid, first, last, club, club_id, country, card, runner_o_class, start_time)
def fullname(self):
return '{} {}'.format(self.first, self.last)
@ -383,6 +387,43 @@ def classes_from_ttime_conf(ttime_file, courses):
loops += 1
return o_classes
def runners_from_xml_entries(xml_file, o_classes=[]):
tree = ET.parse(xml_file)
root = tree.getroot()
runnerarray = []
for person_root in root[1:]:
rid = person_root[1][0].text
first = person_root[1][1][1].text
last = person_root[1][1][0].text
try:
club_id = person_root[2][0].text
club = person_root[2][1].text
except:
club = "None"
country = person_root[1][3].text
try:
card = int(person_root[3].text)
except:
card = 0
try:
xml_class_str = person_root[4][1].text
except:
# VELDIG MIDLERTIDIG
runner_o_class = o_class_list[0]
else:
for i in o_classes:
if i.name == xml_class_str:
runner_o_class = i
break
# Gjør sånn at den lager nye o klasser om den ikke finnes fra før
start_time = None
runnerarray.append(Runner(rid, first, last, club, club_id, country, card, runner_o_class, start_time))
print(rid, first, last, club_id, club, card, xml_class_str)
return runnerarray
# Checks if small list is in big list
def contains(small, big):
valid = True