溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

使用python怎么將控制臺(tái)輸出保存至文件

發(fā)布時(shí)間:2021-05-20 16:32:49 來(lái)源:億速云 閱讀:831 作者:Leah 欄目:開發(fā)技術(shù)

這篇文章給大家介紹使用python怎么將控制臺(tái)輸出保存至文件,內(nèi)容非常詳細(xì),感興趣的小伙伴們可以參考借鑒,希望對(duì)大家能有所幫助。

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è)記錄者類,用來(lái)同時(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'

Python主要用來(lái)做什么

Python主要應(yīng)用于:1、Web開發(fā);2、數(shù)據(jù)科學(xué)研究;3、網(wǎng)絡(luò)爬蟲;4、嵌入式應(yīng)用開發(fā);5、游戲開發(fā);6、桌面應(yīng)用開發(fā)。

關(guān)于使用python怎么將控制臺(tái)輸出保存至文件就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI