自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

一日一技:怎么大于號重定向不過去了?

開發(fā) 前端
很多人應(yīng)該都知道,在命令行中,可以使用大于號>把程序打印出來的文本重定向到文件中。

[[439689]]

很多人應(yīng)該都知道,在命令行中,可以使用大于號>把程序打印出來的文本重定向到文件中。例如,有這樣一個程序:

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

直接運(yùn)行的效果是這樣的:

現(xiàn)在,我們使用>把輸出結(jié)果重定向到一個文件里面:

可以看到,運(yùn)行代碼的時候,程序沒有任何輸出。但當(dāng)我們打開文件的時候,發(fā)現(xiàn)數(shù)據(jù)已經(jīng)在文件里面了。

可是,今天我遇到了一個 Python 文件。直接運(yùn)行的時候,跟正常沒有什么區(qū)別,如下圖所示:

但是,當(dāng)我嘗試重定向的時候,卻發(fā)現(xiàn)數(shù)據(jù)依然是直接打印到終端的,如下圖所示:

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

導(dǎo)致這個問題的原因,是因?yàn)檩敵龅浇K端有兩種方式,分別是stdout和stderr。當(dāng)你直接使用print函數(shù)打印數(shù)據(jù)的時候,你輸出的內(nèi)容默認(rèn)是使用stdout方式輸出的。而>符號默認(rèn)也只會把stdout輸出的內(nèi)容重定向到文件中。如果我們想通過stderr輸出數(shù)據(jù),那么代碼可以這樣寫:

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

通過給print函數(shù)增加一個參數(shù)file=sys.stderr,從而把打印的內(nèi)容通過stderr輸出。這樣直接使用>就不能定向到文件了。

那么,如果我想定向到文件怎么辦呢?這個時候,我們可以修改一下重定向的命令:

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

運(yùn)行效果如下圖所示:

這樣一來,stdout輸出的內(nèi)容,會重定向到out.txt文件中,而stderr輸出的內(nèi)容,會重定向到err.txt中。

如果大家掌握了這個方法,那么在打印日志的時候,我們可以把不同的日志通過不同的方式輸出。如果只需要在命令行看內(nèi)容,那么沒有什么區(qū)別。但是當(dāng)我們想重定向到文件的時候,就可以把不同類型的內(nèi)容區(qū)分開,從而分別處理。這樣數(shù)據(jù)就不會混在一起。

本文轉(zhuǎn)載自微信公眾號「未聞Code」,可以通過以下二維碼關(guān)注。轉(zhuǎn)載本文請聯(lián)系未聞Code公眾號。

 

責(zé)任編輯:武曉燕 來源: 未聞Code
相關(guān)推薦

2021-10-15 21:08:31

PandasExcel對象

2021-04-27 22:15:02

Selenium瀏覽器爬蟲

2021-04-12 21:19:01

PythonMakefile項(xiàng)目

2021-07-08 21:49:13

前端后端Cookies

2023-10-28 12:14:35

爬蟲JavaScriptObject

2021-03-12 21:19:15

Python鏈?zhǔn)?/a>調(diào)用

2022-06-28 09:31:44

LinuxmacOS系統(tǒng)

2021-09-13 20:38:47

Python鏈?zhǔn)?/a>調(diào)用

2021-04-05 14:47:55

Python多線程事件監(jiān)控

2024-11-13 09:18:09

2022-03-12 20:38:14

網(wǎng)頁Python測試

2021-04-19 23:29:44

MakefilemacOSLinux

2024-07-30 08:11:16

2024-07-30 08:16:18

Python代碼工具

2024-11-11 00:38:13

Mypy靜態(tài)類型

2021-07-27 21:32:57

Python 延遲調(diào)用

2021-10-03 20:08:29

HTTP2Scrapy

2024-05-24 09:07:06

JSONprint字符串

2021-05-08 19:33:51

移除字符零寬

2024-07-19 18:23:17

點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號