欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python將控制臺(tái)輸出保存至文件的方法

 更新時(shí)間:2019年01月07日 15:56:37   作者:KFXW  
今天小編就為大家分享一篇python將控制臺(tái)輸出保存至文件的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧

很多時(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)文章

  • Python 相對(duì)路徑報(bào)錯(cuò):"No such file or directory"'原因及解決方法

    Python 相對(duì)路徑報(bào)錯(cuò):"No such file or 

    如果你取相對(duì)路徑不是在主文件里,可能就會(huì)有相對(duì)路徑問題:"No such file or directory",由于python 的相對(duì)路徑,相對(duì)的都是主文件所以會(huì)出現(xiàn)Python 相對(duì)路徑報(bào)錯(cuò),今天小編給大家?guī)砹送昝澜鉀Q方案,感興趣的朋友一起看看吧
    2023-02-02
  • Python面向?qū)ο蟪绦蛟O(shè)計(jì)之類的定義與繼承簡(jiǎn)單示例

    Python面向?qū)ο蟪绦蛟O(shè)計(jì)之類的定義與繼承簡(jiǎn)單示例

    這篇文章主要介紹了Python面向?qū)ο蟪绦蛟O(shè)計(jì)之類的定義與繼承,結(jié)合完整實(shí)例形式分析了Python面向?qū)ο蟪绦蛟O(shè)計(jì)中類的定義、調(diào)用、繼承及相關(guān)操作注意事項(xiàng),需要的朋友可以參考下
    2019-03-03
  • PyTorch使用cpu加載模型運(yùn)算方式

    PyTorch使用cpu加載模型運(yùn)算方式

    今天小編就為大家分享一篇PyTorch使用cpu加載模型運(yùn)算方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-01-01
  • Python臨時(shí)文件創(chuàng)建之tempfile模塊介紹

    Python臨時(shí)文件創(chuàng)建之tempfile模塊介紹

    這篇文章主要介紹了Python臨時(shí)文件創(chuàng)建之tempfile模塊,Python的tempfile模塊是用來創(chuàng)建臨時(shí)文件或者文件夾的跨平臺(tái)工具,下面關(guān)于模塊簡(jiǎn)單介紹需要的小伙伴可以參考一下
    2022-03-03
  • YOLOv5以txt或json格式輸出預(yù)測(cè)結(jié)果的方法詳解

    YOLOv5以txt或json格式輸出預(yù)測(cè)結(jié)果的方法詳解

    這篇文章主要給大家介紹了關(guān)于YOLOv5以txt或json格式輸出預(yù)測(cè)結(jié)果的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2023-03-03
  • 基于pytorch中的Sequential用法說明

    基于pytorch中的Sequential用法說明

    這篇文章主要介紹了基于pytorch中的Sequential用法說明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-06-06
  • Python特性之列表推導(dǎo)式和生成器表達(dá)式詳解

    Python特性之列表推導(dǎo)式和生成器表達(dá)式詳解

    這篇文章主要介紹了python語言的兩個(gè)非常有用的特性:列表推導(dǎo)式和生成器表達(dá)式,但是它們之間也有一些重要的區(qū)別,我們一起來看看吧
    2023-08-08
  • Python-torch?之torch.clamp()?函數(shù)解析

    Python-torch?之torch.clamp()?函數(shù)解析

    torch.clamp()函數(shù)用于對(duì)輸入張量進(jìn)行截?cái)嗖僮?,將張量中的每個(gè)元素限制在指定的范圍內(nèi),這篇文章主要介紹了Python torch之torch.clamp()函數(shù),需要的朋友可以參考下
    2023-05-05
  • Python 的描述符 descriptor詳解

    Python 的描述符 descriptor詳解

    Python中包含了許多內(nèi)建的語言特性,它們使得代碼簡(jiǎn)潔且易于理解。這些特性包括列表/集合/字典推導(dǎo)式,屬性(property)、以及裝飾器(decorator)。對(duì)于大部分特性來說,這些“中級(jí)”的語言特性有著完善的文檔,并且易于學(xué)習(xí)。但是這里有個(gè)例外,那就是描述符。
    2016-02-02
  • 基于python + django + whoosh + jieba 分詞器實(shí)現(xiàn)站內(nèi)檢索功能

    基于python + django + whoosh + jieba 分詞器實(shí)現(xiàn)站內(nèi)檢索功能

    這篇文章主要介紹了基于python + django + whoosh + jieba 分詞器實(shí)現(xiàn)站內(nèi)檢索功能,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-08-08

最新評(píng)論