我已经编写了一些代码来练习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写入文件。你能帮我找一个解决方案吗?
答案 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
对象)。