-
Notifications
You must be signed in to change notification settings - Fork 4
/
logger.py
58 lines (51 loc) · 1.86 KB
/
logger.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
"""Contains the logging class."""
class Logger():
"""Attributes:
fileptr (file): File pointer for input/output.
lines (list of str): The lines read from the log.
"""
def __init__(self, filename, option):
self.fileptr = open(filename, option)
if option == "r":
self.lines = self.fileptr.readlines()
else:
self.lines = []
def put(self, string):
"""Writes to the file."""
self.fileptr.write(string + "\n")
self.fileptr.flush()
def close(self):
"""Closes the logger."""
self.fileptr.close()
def findlast(self, identifier, default=0.):
"""Finds the last line in the log with a certain value."""
for line in self.lines[::-1]:
if line.lower().startswith(identifier):
string = line.strip().split("\t")[1]
if string.replace(".", "").isdigit():
return float(string)
elif string.lower() == "true":
return True
elif string.lower() == "false":
return False
else:
return string
return default
def contains(self, string):
"""Dtermines whether the string is present in the log."""
for line in self.lines[::-1]:
if string.lower() in line.lower():
return True
return False
def findlast_log_before(self, before_str):
"""Finds the last entry in the log before another entry."""
loglines = []
in_line = False
for line in self.lines[::-1]:
if line.startswith(before_str):
in_line = True
elif in_line:
loglines.append(line)
if line.strip() == "" and in_line:
return "".join(loglines[::-1])
return "".join(loglines[::-1])