python将控制台输出保存⾄⽂件的⽅法
很多时候在Linux系统下运⾏python程序时,控制台会输出⼀些有⽤的信息。为了⽅便保存这些信息,有时需要对这些信息进⾏保存。这⾥介绍⼏种将控制台输出保存到⽂件中的⽅式:
1 重定向标准输出流
重定向标准输出流有两种⽅式,既可以在每个print⽅法中进⾏重定向,如下所⽰:
# assume the log file is 'a.log'
# for python2
print >> a.log, 'print something'
# for python3
print('print something', file=a.log)
同时也可以在全局上进⾏设置:
import sys
f = open('a.log', 'a')
sys.stdout = f
sys.stderr = f # redirect std err, if necessary
2 使⽤tee命令重定向
上述⽅法的缺点在于重定向后,控制台就不再显⽰信息,可能对观察程序现象造成困难。使⽤tee命令则可以在保存标准输出的同时在控制台上仍然显⽰信息。使⽤范例如下:
python a_script.py 2>&1 | tee a.log
这种⽅法的缺点是控制台显⽰的内容会断断续续出现,与没有重定向时显⽰的⽅式有些不同。
3 ⾃定义logger
我们可以在python程序中⾃定义⼀个记录者类,⽤来同时写⽂件以及在控制台进⾏显⽰。⼀个例⼦如下:
import sys
class Logger(object):
def __init__(self, filename='default.log', stream=sys.stdout):
self.log = open(filename, 'a')
def write(self, message):
python新手代码图案如何保存self.log.write(message)
def flush(self):
pass
sys.stdout = Logger(a.log, sys.stdout)
sys.stderr = Logger(a.log_file, sys.stderr) # redirect std err, if necessary
# now it works
print 'print something'
此时控制台的显⽰也同原先⼀样正常。
以上这篇python将控制台输出保存⾄⽂件的⽅法就是⼩编分享给⼤家的全部内容了,希望能给⼤家⼀个参考,也希望⼤家多多⽀持。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论