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

Posted 利其器 善其事

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Python3.5 控制台日志输出,区分标准输出与错误输出相关的知识,希望对你有一定的参考价值。

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 控制台日志输出,区分标准输出与错误输出的主要内容,如果未能解决你的问题,请参考以下文章

Linux下运行springboot项目jar包,启动日志输出教程

如何使用 Python 在日志文件中复制/捕获标准输出

有没有办法将系统日志消息重定向到标准输出?

filebeat 多个日志输出到logstash后怎么区分

mybatis-plus日志输出sql配置(控制台能输出sql日志没有sql问题)

C程序设计-格式控制符标准输入输出函数