python將控制臺(tái)輸出保存至文件的方法
很多時(shí)候在Linux系統(tǒng)下運(yùn)行python程序時(shí),控制臺(tái)會(huì)輸出一些有用的信息。為了方便保存這些信息,有時(shí)需要對(duì)這些信息進(jìn)行保存。這里介紹幾種將控制臺(tái)輸出保存到文件中的方式:
1 重定向標(biāo)準(zhǔn)輸出流
重定向標(biāo)準(zhǔn)輸出流有兩種方式,既可以在每個(gè)print方法中進(jìn)行重定向,如下所示:
# assume the log file is 'a.log'
# for python2
print >> a.log, 'print something'
# for python3
print('print something', file=a.log)
同時(shí)也可以在全局上進(jìn)行設(shè)置:
import sys
f = open('a.log', 'a')
sys.stdout = f
sys.stderr = f # redirect std err, if necessary
2 使用tee命令重定向
上述方法的缺點(diǎn)在于重定向后,控制臺(tái)就不再顯示信息,可能對(duì)觀察程序現(xiàn)象造成困難。使用tee命令則可以在保存標(biāo)準(zhǔn)輸出的同時(shí)在控制臺(tái)上仍然顯示信息。使用范例如下:
python a_script.py 2>&1 | tee a.log
這種方法的缺點(diǎn)是控制臺(tái)顯示的內(nèi)容會(huì)斷斷續(xù)續(xù)出現(xiàn),與沒有重定向時(shí)顯示的方式有些不同。
3 自定義logger
我們可以在python程序中自定義一個(gè)記錄者類,用來同時(shí)寫文件以及在控制臺(tái)進(jìn)行顯示。一個(gè)例子如下:
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'
此時(shí)控制臺(tái)的顯示也同原先一樣正常。
以上這篇python將控制臺(tái)輸出保存至文件的方法就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
python3音樂播放器簡(jiǎn)單實(shí)現(xiàn)代碼
這篇文章主要為大家詳細(xì)介紹了python3音樂播放器簡(jiǎn)單實(shí)現(xiàn)代碼,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-06-06
Django項(xiàng)目中動(dòng)態(tài)設(shè)置靜態(tài)文件路徑的全過程
這篇文章主要給大家介紹了關(guān)于Django項(xiàng)目中動(dòng)態(tài)設(shè)置靜態(tài)文件路徑的相關(guān)資料,文中通過圖文介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2022-02-02
Python如何設(shè)置utf-8為默認(rèn)編碼的問題
這篇文章主要介紹了Python如何設(shè)置utf-8為默認(rèn)編碼的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-06-06
在python3中使用Supervisor的詳細(xì)教程
Supervisor是用Python開發(fā)的一個(gè)client/server服務(wù),是Linux/Unix系統(tǒng)下的一個(gè)進(jìn)程管理工具,不支持Windows系統(tǒng),本文給大家介紹在python3中使用Supervisor的方法,感興趣的朋友一起看看吧2022-01-01
DataFrame.to_excel多次寫入不同Sheet的實(shí)例
今天小編就為大家分享一篇DataFrame.to_excel多次寫入不同Sheet的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-12-12
python skimage 連通性區(qū)域檢測(cè)方法
今天小編就為大家分享一篇python skimage 連通性區(qū)域檢測(cè)方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-06-06
Flask實(shí)現(xiàn)異步執(zhí)行任務(wù)
在一些開發(fā)中,可能會(huì)遇到需要長(zhǎng)時(shí)間處理的任務(wù),此時(shí)就需要使用異步的方式來實(shí)現(xiàn),本文就介紹了Flask實(shí)現(xiàn)異步執(zhí)行任務(wù)的方法,感興趣的可以了解一下2021-05-05

