一日一技:怎么>重定向不过去了?
【摘要】 这个功能可以让你有意想不到的用处
很多人应该都知道,在命令行中,可以使用大于号>
把程序打印出来的文本重定向到文件中。例如,有这样一个程序:
for i in range(10):
print(f'这是第{i+1}行')
直接运行的效果是这样的:
现在,我们使用>
把输出结果重定向到一个文件里面:
可以看到,运行代码的时候,程序没有任何输出。但当我们打开文件的时候,发现数据已经在文件里面了。
可是,今天我遇到了一个 Python 文件。直接运行的时候,跟正常没有什么区别,如下图所示:
但是,当我尝试重定向的时候,却发现数据依然是直接打印到终端的,如下图所示:
并且,可以看到生成的 result2.txt 文件也是空的。
导致这个问题的原因,是因为输出到终端有两种方式,分别是stdout
和stderr
。当你直接使用print
函数打印数据的时候,你输出的内容默认是使用stdout
方式输出的。而>
符号默认也只会把stdout
输出的内容重定向到文件中。如果我们想通过stderr
输出数据,那么代码可以这样写:
import sys
for i in range(10):
print(f'这是第{i+1}行', file=sys.stderr)
通过给print
函数增加一个参数file=sys.stderr
,从而把打印的内容通过stderr
输出。这样直接使用>
就不能定向到文件了。
那么,如果我想定向到文件怎么办呢?这个时候,我们可以修改一下重定向的命令:
python3 test_print2.py 1>out.txt 2>err.txt
运行效果如下图所示:
这样一来,stdout
输出的内容,会重定向到out.txt
文件中,而stderr
输出的内容,会重定向到err.txt
中。
如果大家掌握了这个方法,那么在打印日志的时候,我们可以把不同的日志通过不同的方式输出。如果只需要在命令行看内容,那么没有什么区别。但是当我们想重定向到文件的时候,就可以把不同类型的内容区分开,从而分别处理。这样数据就不会混在一起。
【声明】本内容来自华为云开发者社区博主,不代表华为云及华为云开发者社区的观点和立场。转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息,否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
作者其他文章
评论(0)