-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathlogger.py
More file actions
50 lines (43 loc) · 1.46 KB
/
logger.py
File metadata and controls
50 lines (43 loc) · 1.46 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
43
44
45
46
47
48
49
50
__author__ = 'Samuel'
import functools
import logging
import inspect
def initialize_logging(name=None, file_name=None):
if not name:
frame = inspect.stack()[1]
module = inspect.getmodule(frame[0])
logger_name = module.__name__
del module
del frame
log_format = '%(asctime)s %(levelname)s: (%(name)s) %(message)s'
logging.captureWarnings(capture=True)
if file_name:
logging.basicConfig(filename=file_name, format=log_format)
else:
logging.basicConfig(format=log_format)
warnings_log = logging.getLogger('py.warnings')
warnings_log.propagate = False
logger = logging.getLogger(name if name else logger_name)
logger.setLevel(logging.INFO)
return logger
def basic_log(logger=None):
def wrapper_with_args(f):
@functools.wraps(f)
def wrapper(*args, **kwargs):
try:
return f(*args, **kwargs)
except Exception as e:
logger.exception(e)
raise e
return wrapper
return wrapper_with_args
def trace_log(logger=None):
def wrapper_with_args(f):
@functools.wraps(f)
def wrapper(*args, **kwargs):
logger.debug('Entering function %s' % f.__name__)
result = f(*args, **kwargs)
logger.debug('Exiting function %s' % f.__name__)
return result
return wrapper
return wrapper_with_args