self.createWidgets()
self.logDir = ''
self.logFiles = []
+ self.currentFilePath = ''
self.resultsFrame = None
if os.path.exists(LOGS_DIR) :
def loadLogFile(self, nav) :
index = nav.index - 1
filepath = self.logFiles[index]
- filename = basename(filepath)
- self.identFrame.setFileName(filename)
+ self.currentFilePath = filepath
+ lfa = LogFileAnalyser(self.currentFilePath)
+ self.identFrame.refresh(lfa)
if self.resultsFrame :
self.resultsFrame.destroy()
- self.resultsFrame = ResultsFrame(self.dataFrame, filepath)
- self.resultsFrame.layResults()
+ self.resultsFrame = ResultsFrame(self.dataFrame)
+ self.resultsFrame.layResults(lfa)
+ lfa.close()
self.resultsFrame.grid()
def __init__(self, master=None) :
Frame.__init__(self, master)
self.fileName = StringVar()
+ self.patientName = StringVar()
self.createWidgets()
- def setFileName(self, name) :
- self.fileName.set(name)
+ #def setFileName(self, name) :
+ # self.fileName.set(name)
+
+ def refresh(self, lfa) :
+ filename = basename(lfa.logfile.name)
+ self.fileName.set(filename)
+ metadata = lfa.getMetadata()
+ self.patientName.set(metadata.get('PatientName', ''))
+ self.commentsText.delete(1.0, END)
+ self.commentsText.insert(1.0, metadata.get('Comments', ''))
def createWidgets(self) :
fileLbl = Label(self, text='Fichier :')
nameLbl = Label(self, text='Patient :')
nameLbl.grid(row=1, column=0, sticky=E)
- self.nameEntry = Entry(self, width=40)
+ self.nameEntry = Entry(self, width=40, textvariable=self.patientName)
self.nameEntry.grid(row=1, column=1, sticky=W)
commentsLbl = Label(self, text='Commentaires :')
self.commentsText = Text(self, width=40, height=4, undo=True, wrap=WORD)
self.commentsText.grid(row=2, column=1, sticky=W)
+
+ self.saveBtn = Button(self, text='Enregistrer', command=self.saveMetadata)
+ self.saveBtn.grid(row=3, column=1, sticky=E)
+
+ def saveMetadata(self):
+ app = self.master.master
+ filepath = app.currentFilePath
+ lfa = LogFileAnalyser(filepath, mode='r+')
+ patientName = '%s\n' % self.nameEntry.get().replace('\n', ' ').strip()
+ comments = '%s\n' % self.commentsText.get(1.0, END).replace('\n', ' ').strip()
+ metadata = (('PatientName', self.nameEntry.get()),
+ ('Comments', comments))
+ lfa.setMetadata(metadata)
+
class ResultsFrame(Frame) :
- def __init__(self, master, logFilePath) :
- Frame.__init__(self, master)
- self.logFilePath = logFilePath
- def layResults(self) :
- lfa = LogFileAnalyser(self.logFilePath)
+ def layResults(self, lfa) :
results = lfa.analyse()
if results :
for i, kv in enumerate(results) :
classe utilitaire pour l'accès aux données d'un fichier de log MinWii.
"""
- def __init__(self, logfile) :
+ def __init__(self, logfile, mode='r') :
""" logfile : chemin d'accès au fichier de log MinWii.
le format supporté est actuellement la version 1.0 uniquement.
"""
if isinstance(logfile, StringTypes) :
- self.logfile = open(logfile, 'r')
+ self.logfile = open(logfile, mode)
else :
self.logfile = logfile
return lastTicks
def __del__(self) :
- self.logfile.close()
+ self.close()
def __iter__(self) :
return self
while line :
yield line.strip()
line = br.readline()
+
+ @inplaceread
+ def getMetadata(self) :
+ metadata = {}
+ self.next() # skip identification line.
+ line = self.next()
+ while line.startswith('METADATA ') :
+ line = line.split(None, 1)[1]
+ name, value = [v.strip() for v in line.split(':', 1)]
+ metadata[name] = value
+ line = self.next()
+ return metadata
+
+ def setMetadata(self, metadata) :
+ f = self.logfile
+ f.seek(0)
+ before = f.readline()
+ after = f.read()
+
+ lines = []
+ for name, value in metadata :
+ lines.append('METADATA %s : %s' % (name, value.encode('utf-8')))
+ metadata = '\n'.join(lines)
+ f.seek(0)
+ f.write(before)
+ f.write(metadata)
+ f.write(after)
+
+ def close(self) :
+ self.logfile.close()
previousTicks = ticks
self.stop()
-
\ No newline at end of file