[418e14]: / logger.py

Download this file

43 lines (37 with data), 1.1 kB

 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
import pandas as pd
"""
LOGGER
"""
LOG_QUEUE = []
LOGGING = True
def log(msg=None,start=True,end_prev=True,new_level=False,end_level=False):
if not LOGGING: return
tag = ''
now = pd.to_datetime('now') - pd.Timedelta(5, unit='h')
if end_level: end_log_level()
if end_prev and len(LOG_QUEUE) > 0:
level = LOG_QUEUE.pop()
if len(level) > 0:
start_dt = level.pop()
tag = '<<'*(len(LOG_QUEUE)) + ' --- '
__print_entry(now,tag,'({}s)'.format((now-start_dt).total_seconds()))
LOG_QUEUE.append(level)
if msg is None: return
if start:
if len(LOG_QUEUE) == 0: LOG_QUEUE.append([])
tag = '>>'*(len(LOG_QUEUE)-1) + ' '
LOG_QUEUE[-1].append(now)
if new_level: LOG_QUEUE.append([])
else: tag = ''
__print_entry(now,tag,msg)
def __print_entry(dt,tag,msg):
print '({}){}{}'.format(dt,tag,msg)
def end_log_level():
if len(LOG_QUEUE) == 0: return
while len(LOG_QUEUE[-1]) > 0 : log()
LOG_QUEUE.pop()
log()
def end_log():
while len(LOG_QUEUE) > 0 : end_log_level()
def stop_logging():
LOGGING = False