一日一技:怎么大于號重定向不過去了?
很多人應該都知道,在命令行中,可以使用大于號>把程序打印出來的文本重定向到文件中。例如,有這樣一個程序:
- 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中。
如果大家掌握了這個方法,那么在打印日志的時候,我們可以把不同的日志通過不同的方式輸出。如果只需要在命令行看內容,那么沒有什么區別。但是當我們想重定向到文件的時候,就可以把不同類型的內容區分開,從而分別處理。這樣數據就不會混在一起。
本文轉載自微信公眾號「未聞Code」,可以通過以下二維碼關注。轉載本文請聯系未聞Code公眾號。