一日一技:怎么大于号重定向不过去了?

开发 前端
很多人应该都知道,在命令行中,可以使用大于号>把程序打印出来的文本重定向到文件中。

[[439689]]

很多人应该都知道,在命令行中,可以使用大于号>把程序打印出来的文本重定向到文件中。例如,有这样一个程序:

  1. for i in range(10): 
  2.     print(f'这是第{i+1}行'

直接运行的效果是这样的:

现在,我们使用>把输出结果重定向到一个文件里面:

可以看到,运行代码的时候,程序没有任何输出。但当我们打开文件的时候,发现数据已经在文件里面了。

可是,今天我遇到了一个 Python 文件。直接运行的时候,跟正常没有什么区别,如下图所示:

但是,当我尝试重定向的时候,却发现数据依然是直接打印到终端的,如下图所示:

并且,可以看到生成的 result2.txt 文件也是空的。

导致这个问题的原因,是因为输出到终端有两种方式,分别是stdout和stderr。当你直接使用print函数打印数据的时候,你输出的内容默认是使用stdout方式输出的。而>符号默认也只会把stdout输出的内容重定向到文件中。如果我们想通过stderr输出数据,那么代码可以这样写:

  1. import sys 
  2.  
  3. for i in range(10): 
  4.  
  5. print(f'这是第{i+1}行', file=sys.stderr) 

通过给print函数增加一个参数file=sys.stderr,从而把打印的内容通过stderr输出。这样直接使用>就不能定向到文件了。

那么,如果我想定向到文件怎么办呢?这个时候,我们可以修改一下重定向的命令:

  1. python3 test_print2.py 1>out.txt 2>err.txt 

运行效果如下图所示:

这样一来,stdout输出的内容,会重定向到out.txt文件中,而stderr输出的内容,会重定向到err.txt中。

如果大家掌握了这个方法,那么在打印日志的时候,我们可以把不同的日志通过不同的方式输出。如果只需要在命令行看内容,那么没有什么区别。但是当我们想重定向到文件的时候,就可以把不同类型的内容区分开,从而分别处理。这样数据就不会混在一起。

本文转载自微信公众号「未闻Code」,可以通过以下二维码关注。转载本文请联系未闻Code公众号。

 

责任编辑:武晓燕 来源: 未闻Code
相关推荐

2021-10-15 21:08:31

PandasExcel对象

2021-04-27 22:15:02

Selenium浏览器爬虫

2021-04-12 21:19:01

PythonMakefile项目

2023-10-28 12:14:35

爬虫JavaScriptObject

2021-04-05 14:47:55

Python多线程事件监控

2021-09-13 20:38:47

Python链式调用

2022-06-28 09:31:44

LinuxmacOS系统

2024-07-30 08:16:18

Python代码工具

2022-03-12 20:38:14

网页Python测试

2021-03-12 21:19:15

Python链式调用

2024-07-30 08:11:16

2021-04-19 23:29:44

MakefilemacOSLinux

2024-11-13 09:18:09

2021-07-08 21:49:13

前端后端Cookies

2021-07-27 21:32:57

Python 延迟调用

2021-10-03 20:08:29

HTTP2Scrapy

2021-05-08 19:33:51

移除字符零宽

2024-05-24 09:07:06

JSONprint字符串

2024-07-19 18:23:17

2024-11-11 00:38:13

Mypy静态类型
点赞
收藏

51CTO技术栈公众号