很多時候在Linux系統(tǒng)下運行python程序時,控制臺會輸出一些有用的信息。為了方便保存這些信息,有時需要對這些信息進行保存。這里介紹幾種將控制臺輸出保存到文件中的方式:
1 重定向標準輸出流
重定向標準輸出流有兩種方式,既可以在每個print方法中進行重定向,如下所示:
1
2
3
4
5
|
# assume the log file is 'a.log' # for python2 print >> a.log, 'print something' # for python3 print ( 'print something' , file = a.log) |
同時也可以在全局上進行設置:
1
2
3
4
|
import sys f = open ( 'a.log' , 'a' ) sys.stdout = f sys.stderr = f # redirect std err, if necessary |
2 使用tee命令重定向
上述方法的缺點在于重定向后,控制臺就不再顯示信息,可能對觀察程序現(xiàn)象造成困難。使用tee命令則可以在保存標準輸出的同時在控制臺上仍然顯示信息。使用范例如下:
1
|
python a_script.py 2 >& 1 | tee a.log |
這種方法的缺點是控制臺顯示的內(nèi)容會斷斷續(xù)續(xù)出現(xiàn),與沒有重定向時顯示的方式有些不同。
3 自定義logger
我們可以在python程序中自定義一個記錄者類,用來同時寫文件以及在控制臺進行顯示。一個例子如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
import sys class Logger( object ): def __init__( self , filename = 'default.log' , stream = sys.stdout): self .terminal = stream self .log = open (filename, 'a' ) def write( self , message): self .terminal.write(message) self .log.write(message) def flush( self ): pass sys.stdout = Logger(a.log, sys.stdout) sys.stderr = Logger(a.log_file, sys.stderr) # redirect std err, if necessary # now it works print 'print something' |
此時控制臺的顯示也同原先一樣正常。
以上這篇python將控制臺輸出保存至文件的方法就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持服務器之家。
原文鏈接:https://blog.csdn.net/u010158659/article/details/81671901