logconf.py 1.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142
  1. '''
  2. Created on 6 juil. 2017
  3. @author: olivier.massot
  4. '''
  5. from datetime import datetime
  6. import logging.config
  7. import sys
  8. import traceback
  9. import yaml
  10. from core.pde import DEFAULT_LOG_DIR, LOG_CONFIG_FILE
  11. SYS_EXCEPT_HOOK = sys.excepthook
  12. def start(name="main", level=0, filename=""):
  13. # charge la configuration du logging depuis le fichier 'logging.yaml'
  14. with open(LOG_CONFIG_FILE, 'rt') as f:
  15. conf = yaml.load(f)
  16. if level:
  17. conf["loggers"][name]["level"] = level
  18. if not filename:
  19. filename = DEFAULT_LOG_DIR / r'{}_{:%Y%m%d_%H%M}.log'.format(name, datetime.now())
  20. conf["handlers"]["file"]["filename"] = filename
  21. conf["handlers"]["mail"]["fromaddr"] = conf["handlers"]["mail"]["fromaddr"].replace("%name%", name)
  22. conf["handlers"]["mail"]["subject"] = conf["handlers"]["mail"]["subject"].replace("%name%", name)
  23. logging.config.dictConfig(conf)
  24. logger = logging.getLogger(name)
  25. def _excepthook(typ, value, trace):
  26. """ Remplace la gestion d'erreur standard, pour logger aussi les erreurs non gérées """
  27. logger.error("{}\n{}\n{}".format(typ.__name__, value, ''.join(traceback.format_tb(trace))))
  28. SYS_EXCEPT_HOOK(typ, value, trace)
  29. sys.excepthook = _excepthook