What?

在 Python 程序中,使用 print 输出调试信息的做法非常常见,但有的时候我们需要将 print 的内容改写到其他位置,比如一个文件中,便于随时排查。

但是又不希望大面积替换 print 函数,这就需要一些技巧实现。

一种典型的做法是在代码开始的地方增加这样的代码:

def log_to_file(* args):

# write all args to some a file

pass

print = log_to_file

修改 print 方法,之后的 print 实际上就不是内置方法了。

在 Linux 下也可以通过 shell 的输出重定向,将 print 的内容写入文件:

python3 your_script.py >> log.txt

其实在 Python 代码中,也可以通过输出重定向技术,直接实现上面的目的。

重定向 stdout

stdout 是系统的标准输出,通常是 shell 命令行。如果我们用其他对象覆盖 sys.stdout 就可以实现输出的重定向。

Python 使用任意实现了 write 方法的对象作为标准输出对象。

下面定义了一个 OutputWrapper:

class OutputWrapper:

def __init__(self, to_file):

self._to = to_file

def write(self, data):

# let's write to log file with some extra string.

self._to.write("-----")

self._to.write(data)

它实现了 write 方法,它将输出内容写入 to_file, 我们再多做一点工作,在每次调用 print 前插入一段 “-----”。

下面我们用 OutputWrapper 实例替换原生 sys.stdout:

import sys

if __name__ == '__main__':

# the log file name

logname = 'log.txt'

with open(logname,'a') as logfile:

# save original stdout

original = sys.stdout

# redirect stdout

sys.stdout = OutputWrapper(logfile)

# output

print('line 1')

print('line 2')

# restore stdout

sys.stdout = original

运行时命令行的输出消失了,如果查看 log.txt :

-----line 1-----

-----line 2-----

原来 print 的内容已经写到文件中了,此时 log.txt 就相当于命令行输出了。

为什么 “line1” 和 “line2” 后面也多了额外输出呢?这是因为 print 方法会自动在尾部追加输出一个 ‘\n’,又调用了一次 print(’\n’)。

How ?

这种重定向技术是如何实现的?其实一切就在最熟悉不过的 print 方法中。

print 方法是 Python 的内建函数,其原型为:

print(*objects, sep=' ', end='\n', file=sys.stdout, flush=False)第一个参数是不定参数,表示 print 的对象;

sep 是多个输出对象之间的分隔符,所以 print(‘a’, ‘b’) 会输出 “a b”,这是因为 sep 默认是空格,你也可以设置为其他字符串;

end 是行位字符,默认是换行,这也是 print 总是一行的原因,如果不希望换行,可以用参数 end = “”;

file 非常重要,表示 print 方法的输出对象,最终的输出工作是通过 file.write 实现的,默认情况下 file = sys.stdout。

flush 与输出缓冲有关,暂时不必关心。

前面的输出重定向可以总结为这样的流程:修改了 sys.stdout --> print 默认 file = sys.stdout --> 间接修改了 print 的输出对象。

原来如此!Built-in Functions​docs.python.org

首发公众号 “江川Go”,关注了解程序员的烧脑日常。

python 重定向stdout_Python 犄角旮旯--重定向 stdout相关推荐

  1. python标准输入stdout_python 标准输出 sys.stdout 重定向

    环境:python2.7 1.sys.stdout 和 print 关系 调用 python 打印对象 print obj的时候,事实上其实是都用了 sys.stdout.write(obj+'\n' ...

  2. python输入输出重定向_Python标准输出重定向

    Python标准输出重定向 标签: Python stdout 重定向 声明 本文基于Python2.7版本,介绍常见的几种标准输出(stdout)重定向方式.显然,这些方式也适用于标准错误重定向. ...

  3. python爬虫解决网页重定向问题

    python爬虫解决网页重定向问题 参考文章: (1)python爬虫解决网页重定向问题 (2)https://www.cnblogs.com/zhumengke/articles/9618368.h ...

  4. python stdout_python 之sys.stdout小记

    标准输出(sys.stdout)-->print(打印) 标准输入(sys.stdin)-->input(接收输入) 标准错误输出和标准输出类似也是print(打印). python最基本 ...

  5. Linux shell 学习笔记(11)— 理解输入和输出(标准输入、输出、错误以及临时重定向和永久重定向)

    1. 理解输入和输出 1.1 标准文件描述符 Linux 系统将每个对象当作文件处理.这包括输入和输出进程.Linux 用文件描述符(file descriptor)来标识每个文件对象.文件描述符是一 ...

  6. linux shell数据重定向(输入重定向与输出重定向)详细分析

    转载自: linux shell数据重定向(输入重定向与输出重定向)详细分析 - 程默 - 博客园 http://www.cnblogs.com/chengmo/archive/2010/10/20/ ...

  7. 输入重定向,输出重定向,管道相关内容及实现方法

    近期,通过实现shell了解了输入重定向,输出重定向,管道- 用自己的话总结定义: 输入重定向:把<右边的文件的内容输入到<左边的命令中. 输出重定向:把运行>左边命令得出的结果输入 ...

  8. 重定向java_JAVA 中 重定向

    1.request.getRequestDispatcher("/Login.jsp").forward(request, response); 三.重定向与转发的区别: 1.重定 ...

  9. 什么是301重定向与301重定向怎么做

    上一次在URL是什么意思与统一URL优化中谈到统一URL.优化网站可以使用301重定向的方法.现在我们可以交流一下"什么是301重定向,301重定向怎么做",还有什么时候什么情况下 ...

最新文章

  1. Flutter面试常见开发问题
  2. Java实现查询菜单返回树结构
  3. 当执行进程ctrl+c关闭不了的时候的解决方法
  4. bolt在java,java – 在Apache Storm中将不同的元组从1个spout发送到不同的bolt
  5. [Python] 更改矩阵形状:reshape(m,n)、view(m,n)和view_as(tensor)
  6. 不重装,不还原,不优化,让你的系统比重装还爽
  7. 怎么卸载Office2007兼容包?
  8. 对12w条数据进行相关清理和数据迁移 (数据清理项目实战完整版)文章内有大量sql脚本
  9. 前端基础入门课程推荐
  10. [20181031]如何确定db_link的进程号.txt
  11. 2017年6月六级翻译明朝
  12. 2021 增强式学习RL 李宏毅
  13. vue 前端传图片文件,后端接收
  14. 计算机加入域的一种方法
  15. 前端:zoom的缩放功能,以及overflow介绍
  16. 关于湖北美术学院花坛长出娃娃
  17. [词性] 十八、介词 8 [ within ] [ within ] [ across ] [ among ] [ outside ] [ into ] [ beyond ] [ against ]
  18. 【OpenEVSE 】汽车充电桩控制项目解析
  19. 解决ERROR Error: Cannot find module ‘@sentry/webpack-plugin‘,或Unable to download sentry-cli binary 问题
  20. 45页智慧交通数字化解决方案2022

热门文章

  1. php指定字符编码,PHP字符编码问题
  2. 主机安装php网站,php支持虚拟主机(php网站空间)
  3. 使用未初始化的内存是什么意思_他们都说JVM能实际使用的内存比-Xmx指定的少?这是为什么呢...
  4. 服务器内存超限问题_服务器内存爆满最佳处置方案
  5. mysql修改表的字段_mysql修改表字段学习笔记
  6. easyui中onchange事件_React中类似Vue的“模板语法”
  7. kernal tch 下载 天正_tch kernal.arx
  8. 后处理安装_Mastercam2017(自定义后处理选项)安装!
  9. python变量区变量保存与加载_python – Flask:使用全局变量将数据文件加载到内存中...
  10. oracle =1,oracle中的 where 1=1 和where 1 !=1