web-dev-qa-db-ja.com

Python stdoutとstderrの間のロギング分割

python INFOまたはDEBUGでstdoutに移動し、WARNING以上でstderrに移動するメッセージをログに記録することは可能ですか?

20
crosswired

これは私が望むことをするようです:

    #!/usr/bin/python
    import sys
    import logging

    class InfoFilter(logging.Filter):
        def filter(self, rec):
            return rec.levelno in (logging.DEBUG, logging.INFO)

    logger = logging.getLogger('__name__')
    logger.setLevel(logging.DEBUG)

    h1 = logging.StreamHandler(sys.stdout)
    h1.setLevel(logging.DEBUG)
    h1.addFilter(InfoFilter())
    h2 = logging.StreamHandler()
    h2.setLevel(logging.WARNING)

    logger.addHandler(h1)
    logger.addHandler(h2)
38
crosswired