将stdout重定向到打开或关闭详细程度的控制台和文件

时间:2014-03-01 18:41:20

标签: python stdout verbosity

我已经编写了一些代码来练习python中的详细程度。通过ArgumentParser模块嵌入详细程度。但是,当禁用详细程度时,我还想将stdout写入文件:

#!/usr/bin/python                                                               
import sys

def printable1():
    print "1"

def printable2():
    print "2"

def printable3():
    print "3"

def Main1():
    printable1()
    printable2()

def Main2():
    printable2()
    printable3()

class Logger(object):
    def __init__(self):
        self.terminal = sys.stdout
        self.log = open("logfile2.log", "a")

    def write(self, message):
        self.terminal.write(message)
        self.log.write(message)


if __name__ == "__main__":
    from argparse import ArgumentParser

    parser = ArgumentParser(description='PC Test',version="1.0")
    parser.add_argument('--nopc',action='store_true', help='Do not perform test on the PC')
    parser.add_argument('--pc', action='store_true', help='Do perform test on the PC')

    # VERBOSITY 
    parser.add_argument('--vmode', dest='verbose', action='store_true',
                        help='Enable printing of status messages to stdout.')

    args = parser.parse_args()

    sys.stdout = Logger()

    if args.verbose:
        if args.pc:       
            Main1()
        elif args.nopc:
            Main2()
        else:
            Main1()
            Main2()  

只有在使用--vmode参数启用详细程度时,此代码才会将stdout写入文件。你能帮我找一个解决方案吗?

1 个答案:

答案 0 :(得分:1)

您可以使用logging模块处理打印到终端并写入文件,而不是重新发明轮子。详细部分仍由你决定:

import logging
import logging.handlers
log = logging.getLogger(__name__)
log.addHandler(logging.StreamHandler())  # Prints to console.
log.addHandler(logging.handlers.RotatingFileHandler('logfile2.log'))
log.setLevel(logging.INFO)  # Set logging level here.

从现在开始,您可以使用该常规log对象在脚本中执行日志记录,并将条目发送到控制台和文件:

log.info('test')
log.warning('test')

另外,我建议使用ConfigDict来处理注册记录器和处理程序 - 这是上述方法的一种更具声明性的替代方法(您仍然需要像上面那样实例化log对象)。