首页 > 编程语言 > 详细

Python3.5 控制台日志输出,区分标准输出与错误输出

时间:2018-01-24 11:55:39      阅读:272      评论:0      收藏:0      [点我收藏+]
import logging
import sys


class ConsoleHandler(logging.Handler):
    terminator = \n

    def __init__(self, level=logging.NOTSET):
        super().__init__(level)

    def _flush(self, stream):
        self.acquire()
        try:
            if stream and hasattr(stream, flush):
                stream.flush()
        finally:
            self.release()

    def emit(self, record):
        try:
            msg = self.format(record)
            stream = sys.stderr if record.levelname == ERRORelse sys.stdout
            stream.write(msg)
            stream.write(self.terminator)
            self._flush(stream)
        except BaseException as ex:
            record.msg = record.getMessage() +  WriteLogException: + str(ex)
            self.handleError(record)


if __name__ == "__main__":
    _logger = logging.root
    _logger.setLevel(logging.INFO)
    formatter = logging.Formatter(%(asctime)s %(filename)s[line:%(lineno)d] %(levelname)s %(message)s)
    _console_handler = ConsoleHandler(logging.INFO)
    _console_handler.setFormatter(formatter)
    _logger.addHandler(_console_handler)
    logging.info(info)
    logging.error(error)

 

Python3.5 控制台日志输出,区分标准输出与错误输出

原文:https://www.cnblogs.com/stones/p/8340864.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!