-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathlogger_config.py
More file actions
36 lines (28 loc) · 1.03 KB
/
logger_config.py
File metadata and controls
36 lines (28 loc) · 1.03 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
import logging
import sys
from datetime import datetime
from config import Config
class TradingLogger:
_instance = None
_logger = None
def __new__(cls):
if cls._instance is None:
cls._instance = super(TradingLogger, cls).__new__(cls)
cls._instance._setup_logger()
return cls._instance
def _setup_logger(self):
self._logger = logging.getLogger('TradingAI')
self._logger.setLevel(getattr(logging, Config.LOG_LEVEL))
if not self._logger.handlers:
handler = logging.StreamHandler(sys.stdout)
handler.setLevel(getattr(logging, Config.LOG_LEVEL))
formatter = logging.Formatter(
'%(asctime)s - %(name)s - %(levelname)s - %(message)s',
datefmt='%Y-%m-%d %H:%M:%S'
)
handler.setFormatter(formatter)
self._logger.addHandler(handler)
def get_logger(self):
return self._logger
def get_logger():
return TradingLogger().get_logger()