python将控制台输出保存至文件的方法


Posted in Python onJanuary 07, 2019

很多时候在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.terminal = stream
  self.log = open(filename, 'a')

 def write(self, message):
  self.terminal.write(message)
  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将控制台输出保存至文件的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python求解平方根的方法
Mar 11 Python
Python循环语句之break与continue的用法
Oct 14 Python
windows及linux环境下永久修改pip镜像源的方法
Nov 28 Python
pandas带有重复索引操作方法
Jun 08 Python
Tensorflow 查看变量的值方法
Jun 14 Python
Python将多个list合并为1个list的方法
Jun 27 Python
对python实现合并两个排序链表的方法详解
Jan 23 Python
Python使用python-docx读写word文档
Aug 26 Python
基于python实现文件加密功能
Jan 06 Python
tensorflow 实现打印pb模型的所有节点
Jan 23 Python
Matplotlib.pyplot 三维绘图的实现示例
Jul 28 Python
python爬不同图片分别保存在不同文件夹中的实现
Apr 02 Python
对Python捕获控制台输出流的方法详解
Jan 07 #Python
python print输出延时,让其立刻输出的方法
Jan 07 #Python
Python3 单行多行万能正则匹配方法
Jan 07 #Python
Python字符串的全排列算法实例详解
Jan 07 #Python
Python 3.3实现计算两个日期间隔秒数/天数的方法示例
Jan 07 #Python
Python进阶之自定义对象实现切片功能
Jan 07 #Python
Python基于matplotlib画箱体图检验异常值操作示例【附xls数据文件下载】
Jan 07 #Python
You might like
php生成随机密码的三种方法小结
2010/09/04 PHP
php实现获取文件mime类型的方法
2015/02/11 PHP
PHP使用array_fill定义多维数组的方法
2015/03/18 PHP
javascript 拖动表格行实现代码
2011/05/05 Javascript
jQuery代码优化 事件委托篇
2011/11/01 Javascript
JS实现悬浮移动窗口(悬浮广告)的特效
2013/03/12 Javascript
js 数组操作之pop,push,unshift,splice,shift
2014/01/29 Javascript
做web开发 先学JavaScript
2014/12/12 Javascript
学习JavaScript设计模式(多态)
2015/11/25 Javascript
Extjs4.0 ComboBox如何实现三级联动
2016/05/11 Javascript
详解JavaScript中Hash Map映射结构的实现
2016/05/21 Javascript
jQuery使用正则表达式替换dom元素标签用法示例
2017/01/16 Javascript
几种响应式文字详解
2017/05/19 Javascript
JavaScript对象拷贝与Object.assign用法实例分析
2018/06/20 Javascript
js实现点击展开隐藏效果(实例代码)
2018/09/28 Javascript
微信小程序学习笔记之登录API与获取用户信息操作图文详解
2019/03/29 Javascript
浅谈Vue static 静态资源路径 和 style问题
2020/11/07 Javascript
Python中运行并行任务技巧
2015/02/26 Python
Python对数据库操作
2016/03/28 Python
50行Python代码实现人脸检测功能
2018/01/23 Python
python实现逆序输出一个数字的示例讲解
2018/06/25 Python
python3学生名片管理v2.0版
2018/11/29 Python
Python3数字求和的实例
2019/02/19 Python
利用django model save方法对未更改的字段依然进行了保存
2020/03/28 Python
哪些是python中web开发框架
2020/06/17 Python
python实现控制台输出颜色
2021/03/02 Python
马来西亚演唱会订票网站:StubHub马来西亚
2018/10/18 全球购物
银行员工职业规划范文
2014/01/21 职场文书
北体毕业生求职信
2014/02/28 职场文书
《记金华的双龙洞》教学反思
2014/04/19 职场文书
大学生个人先进事迹材料范文
2014/05/03 职场文书
战略合作意向书
2014/07/29 职场文书
大学生暑期实践报告
2015/07/13 职场文书
只用50行Python代码爬取网络美女高清图片
2021/06/02 Python
python+opencv实现视频抽帧示例代码
2021/06/11 Python
SpringBoot项目部署到阿里云服务器的实现步骤
2022/06/28 Java/Android