前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >python将print输出结果写入文件

python将print输出结果写入文件

作者头像
种花家的奋斗兔
发布2020-11-13 10:48:51
10.8K0
发布2020-11-13 10:48:51
举报
文章被收录于专栏:NLP小白的学习历程

1.重定向

代码语言:javascript
复制
python -u test.py > a.log
# 将打印的结果输出到log -u是清空变量

有第一个就足够了,其实。

2. 其他参考:

1 重定向标准输出流

重定向标准输出流有两种方式,既可以在每个print方法中进行重定向,如下所示:

代码语言:javascript
复制
# assume the log file is 'a.log'
# for python2
print >> a.log, 'print something'
# for python3
print('print something', file=a.log)

同时也可以在全局上进行设置:

代码语言:javascript
复制
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

代码语言:javascript
复制
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程序中自定义一个记录者类,用来同时写文件以及在控制台进行显示。一个例子如下: 此时控制台的显示也同原先一样正常。

参考:https://blog.csdn.net/u010158659/article/details/81671901

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2019/11/28 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1.重定向
  • 2. 其他参考:
    • 1 重定向标准输出流
      • 同时也可以在全局上进行设置:
        • 2 使用tee命令重定向
          • 3 自定义logger
          领券
          问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档