溫馨提示×

溫馨提示×

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

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

python如何實現(xiàn)信息同時輸出到控制臺與文件

發(fā)布時間:2021-07-23 13:55:58 來源:億速云 閱讀:187 作者:小新 欄目:開發(fā)技術

這篇文章主要為大家展示了“python如何實現(xiàn)信息同時輸出到控制臺與文件”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“python如何實現(xiàn)信息同時輸出到控制臺與文件”這篇文章吧。

python編程中,往往需要將結(jié)果用print等輸出,如果希望輸出既可以顯示到IDE的屏幕上,也能存到文件中(如txt)中,該怎么辦呢?

方法1

可通過日志logging模塊輸出信息到文件或屏幕。但可能要設置log的level或輸出端,對于同時需要記錄debug error等信息的較為合適,官方教程推薦學習用更規(guī)范的logger來操作。

例如,可參考來自官網(wǎng)的這段代碼。

import logging
logging.basicConfig(filename='log_examp.log',level=logging.DEBUG)
logging.debug('This message should go to the log file')
logging.info('So should this')
logging.warning('And this, too')

方法2

利用print輸出兩次

比如這里我想輸出程序的path和程序的文件名

import os
# 第一句輸出到consle:
print("filepath:",__file__,"\nfilename:",os.path.basename(__file__))
# 第二句輸出到txt:
with open("outputlog.txt","a+") as f:
 print("filepath:",__file__,
 "\nfilename:",os.path.basename(__file__))
 #當然 也可以用f.write("info")的方式寫入文件

方法3

利用輸出重定向輸出兩次

同樣輸出程序path和文件名

import os
import sys
temp=sys.stdout # 記錄當前輸出指向,默認是consle
with open("outputlog.txt","a+") as f:
 sys.stdout=f # 輸出指向txt文件
 print("filepath:",__file__,
 "\nfilename:",os.path.basename(__file__))
 print("some other information")
 print("some other")
 print("information")
 sys.stdout=temp # 輸出重定向回consle
 print(f.readlines()) # 將記錄在文件中的結(jié)果輸出到屏幕

R的重定向

這里多嘴補充一下,在windows下的R語言中,有個sink(‘文件名.后綴名') 可以將輸出重定向到文件中,然后用sink()重返控制臺 很是方便

以上是“python如何實現(xiàn)信息同時輸出到控制臺與文件”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業(yè)資訊頻道!

向AI問一下細節(jié)

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

AI