国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

python將控制臺輸出保存至文件的方法

2020-02-16 00:30:47
字體:
來源:轉載
供稿:網友

很多時候在Linux系統下運行python程序時,控制臺會輸出一些有用的信息。為了方便保存這些信息,有時需要對這些信息進行保存。這里介紹幾種將控制臺輸出保存到文件中的方式:

1 重定向標準輸出流

重定向標準輸出流有兩種方式,既可以在每個print方法中進行重定向,如下所示:

# assume the log file is 'a.log'# for python2print >> a.log, 'print something'# for python3print('print something', file=a.log)

同時也可以在全局上進行設置:

import sysf = open('a.log', 'a')sys.stdout = fsys.stderr = f # redirect std err, if necessary

2 使用tee命令重定向

上述方法的缺點在于重定向后,控制臺就不再顯示信息,可能對觀察程序現象造成困難。使用tee命令則可以在保存標準輸出的同時在控制臺上仍然顯示信息。使用范例如下:

python a_script.py 2>&1 | tee a.log

這種方法的缺點是控制臺顯示的內容會斷斷續續出現,與沒有重定向時顯示的方式有些不同。

3 自定義logger

我們可以在python程序中自定義一個記錄者類,用來同時寫文件以及在控制臺進行顯示。一個例子如下:

import sysclass 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):  passsys.stdout = Logger(a.log, sys.stdout)sys.stderr = Logger(a.log_file, sys.stderr) # redirect std err, if necessary# now it worksprint 'print something'

此時控制臺的顯示也同原先一樣正常。

以上這篇python將控制臺輸出保存至文件的方法就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持武林站長站。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 彭州市| 襄汾县| 温州市| 湘乡市| 靖江市| 白银市| 德钦县| 嘉义市| 成武县| 黄梅县| 绥德县| 西丰县| 济南市| 卢氏县| 蒙山县| 七台河市| 随州市| 称多县| 邵武市| 江达县| 南丹县| 牙克石市| 巴中市| 南和县| 门源| 宁波市| 长泰县| 莆田市| 万安县| 社旗县| 阿巴嘎旗| 临江市| 瓦房店市| 合水县| 广东省| 壶关县| 祁阳县| 江阴市| 额济纳旗| 湖北省| 江北区|