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实现电子词典
Apr 23 Python
跟老齐学Python之有容乃大的list(1)
Sep 14 Python
Python导出数据到Excel可读取的CSV文件的方法
May 12 Python
详解Python中映射类型(字典)操作符的概念和使用
Aug 19 Python
浅析PHP与Python进行数据交互
May 15 Python
python删除本地夹里重复文件的方法
Nov 19 Python
在Mac上删除自己安装的Python方法
Oct 29 Python
自定义实现 PyQt5 下拉复选框 ComboCheckBox的完整代码
Mar 30 Python
Python基于smtplib协议实现发送邮件
Jun 03 Python
keras slice layer 层实现方式
Jun 11 Python
Python实现ElGamal加密算法的示例代码
Jun 19 Python
Ubuntu16安装Python3.9的实现步骤
Dec 15 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数组实现无限分类,不使用数据库,不使用递归.
2006/12/09 PHP
深入理解PHP中的Streams工具
2015/07/03 PHP
php实现CSV文件导入和导出
2015/10/24 PHP
JQuery 常用方法基础教程
2009/02/06 Javascript
代码触发js事件(click、change)示例应用
2013/12/13 Javascript
使用JavaScript获取电池状态的方法
2014/05/03 Javascript
JavaScript中eval()函数用法详解
2015/12/14 Javascript
vue集成百度UEditor富文本编辑器使用教程
2018/09/21 Javascript
vue项目环境变量配置的实现方法
2018/10/12 Javascript
从零到一详聊创建Vue工程及遇到的常见问题
2019/04/25 Javascript
微信小程序之侧边栏滑动实现过程解析(附完整源码)
2019/08/23 Javascript
uniapp 仿微信的右边下拉选择弹出框的实现代码
2020/07/12 Javascript
小程序自动化测试的示例代码
2020/08/11 Javascript
详解windows python3.7安装numpy问题的解决方法
2018/08/13 Python
浅谈Python脚本开头及导包注释自动添加方法
2018/10/27 Python
python调用虹软2.0第三版的具体使用
2019/02/22 Python
Python魔法方法功能与用法简介
2019/04/04 Python
Python统计文本词汇出现次数的实例代码
2020/02/27 Python
python实现在线翻译
2020/06/18 Python
pytorch Dataset,DataLoader产生自定义的训练数据案例
2021/03/03 Python
利用HTML5的新特点实现图片文件异步上传
2014/05/29 HTML / CSS
adidas旗下高尔夫装备供应商:TaylorMade Golf(泰勒梅高尔夫)
2016/08/28 全球购物
英国最大的线上保健品零售商之一:Vitamin Planet
2016/12/01 全球购物
学校司机岗位职责
2013/11/14 职场文书
办公室内勤岗位职责范本
2013/12/09 职场文书
自荐信如何制作?
2014/02/21 职场文书
初一新生军训方案
2014/05/22 职场文书
2014国庆节主题活动方案:快乐的国庆节
2014/09/16 职场文书
贫困证明模板(3篇)
2014/09/16 职场文书
2014超市双十一活动策划方案
2014/09/29 职场文书
2014年酒店前台工作总结
2014/11/14 职场文书
暂住证明怎么写
2015/06/19 职场文书
2016年母亲节寄语
2015/12/04 职场文书
《清澈的湖水》教学反思
2016/02/17 职场文书
利用JavaScript写一个简单计算器
2021/11/27 Javascript
Python集合set()使用的方法详解
2022/03/18 Python