时间:2021-05-22
很多时候在Linux系统下运行python程序时,控制台会输出一些有用的信息。为了方便保存这些信息,有时需要对这些信息进行保存。这里介绍几种将控制台输出保存到文件中的方式:
1 重定向标准输出流
重定向标准输出流有两种方式,既可以在每个print方法中进行重定向,如下所示:
# assume the log file is 'a.log'# for python2print >> a.log, 'print something'# for python3print('print something', file=a.log)同时也可以在全局上进行设置:
import sysf = open('a.log', 'a')sys.stdout = fsys.stderr = f # redirect std err, if necessary2 使用tee命令重定向
上述方法的缺点在于重定向后,控制台就不再显示信息,可能对观察程序现象造成困难。使用tee命令则可以在保存标准输出的同时在控制台上仍然显示信息。使用范例如下:
python a_script.py 2>&1 | tee a.log这种方法的缺点是控制台显示的内容会断断续续出现,与没有重定向时显示的方式有些不同。
3 自定义logger
我们可以在python程序中自定义一个记录者类,用来同时写文件以及在控制台进行显示。一个例子如下:
import sysclass Logger(object): def __init__(self, filename='default.log', stream=sys.stdout): self.terminal = stream self.log = open(filename, 'a') def write(self, message): self.terminal.write(message) self.log.write(message) def flush(self): passsys.stdout = Logger(a.log, sys.stdout)sys.stderr = Logger(a.log_file, sys.stderr) # redirect std err, if necessary# now it worksprint 'print something'此时控制台的显示也同原先一样正常。
以上这篇python将控制台输出保存至文件的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例为大家分享了python实现控制台输出颜色的具体代码,供大家参考,具体内容如下python控制台输出颜色,out()是基本方法,还封装了一些基本颜色方法
本文实例讲述了Python同时向控制台和文件输出日志logging的方法。分享给大家供大家参考。具体如下:python提供了非常方便的日志模块,可实现同时向控制
shell脚本基本技能是设置变量,输出信息。如下:sh脚本输出到控制台将以上脚本保存到test.sh脚本文件中,并赋予可执行权限:sudochmod+xtest
本文实例讲述了C#实现在控制台输出当前系统时间的方法。分享给大家供大家参考。具体实现方法如下://C#实现的小控制台程序:动态输出当前时间usingSystem
js中遍历Map对象的方法console.log(jsonData);//火狐控制台打印输出:Object{fileNumber="文件编号",fileName