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

python中屏蔽輸出示例詳解

 更新時間:2024年05月29日 14:49:41   作者:JHW5981  
python中屏蔽輸出包含屏蔽標準輸出(比如打印出來的內(nèi)容)、屏蔽標準錯誤(錯誤信息)還有屏蔽logging信息等,這篇文章主要介紹了python中屏蔽輸出,需要的朋友可以參考下

python中屏蔽輸出包含屏蔽標準輸出(比如打印出來的內(nèi)容)、屏蔽標準錯誤(錯誤信息)還有屏蔽logging信息等。

屏蔽標準輸出

import contextlib
import os
with open(os.devnull, "w") as devnull:
    with contextlib.redirect_stdout(devnull):
        print("Hello, World!")

運行上面的代碼會發(fā)現(xiàn),沒有任何輸出,因為`redirect_stdout`表示將標準輸出的內(nèi)容給定義到devnull去了,`os.devnull`是一個特殊的文件路徑,在Unix-like系統(tǒng)上通常是`/dev/null`,在Windows上是`NUL`。它的作用是丟棄所有寫入其中的數(shù)據(jù)。

屏蔽標準錯誤

屏蔽標準錯誤只需要把上面代碼中的`stdout`改成`stderr`就好了。

可以看到屏蔽標準錯誤不會屏蔽標準輸出,但是屏蔽標準輸出不是屏蔽異常,

異常該顯示還顯示,屏蔽異常的話,就目前我了解只有用try-except了。

上面的是正常的,將輸出寫到標準錯誤里是可以屏蔽的,但是好像很少有人會這么寫吧。。。

而且`print("xxx" file=sys.stdout)`和`print("xxx", file=sys.stderr)`貌似沒有什么區(qū)別,都將“xxx”打印到控制臺,關于此,chatgpt是這樣解釋的

反正我是覺得這個屏蔽標準錯誤的用法有點子雞肋。

屏蔽logging信息

屏蔽logging也是很常用的,上面的方法對logging信息沒有用,需要logging本身的設置

將logging的handler直接置空還是有l(wèi)ogging信息被打印出來,原因是,代碼中,即使你清除了 `logger.handlers` 列表,`logging `模塊可能會自動添加一個默認的處理器來處理日志消息。默認情況下,日志消息等級為 `WARNING `及以上的消息會被顯示在控制臺上。這解釋了為什么你仍然看到 `WARNING `及以上級別的消息。

如果要完全屏蔽到logging的信息,需要自己寫個handler,加進去

這下啥都沒有了。當然也可以在`emit`這個函數(shù)里面對record進行一些處理,其中record有哪些屬性可用呢?這里給出一個可以查record屬性的代碼示例

import logging
class NullHandler(logging.Handler):
    def emit(self, record):
        # 獲取所有屬性并打印
        for attr in dir(record):
            if not attr.startswith('__'):
                print(f'{attr}: {getattr(record, attr)}')
        pass
logging.basicConfig(level=logging.DEBUG)
logger = logging.getLogger()
logger.handlers = []
logger.addHandler(NullHandler())
logger.debug("This debug message will be discarded.")

到此這篇關于python中屏蔽輸出的文章就介紹到這了,更多相關python屏蔽輸出內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • python變量賦值機制踩坑記錄

    python變量賦值機制踩坑記錄

    這篇文章主要介紹了python變量賦值機制踩坑記錄,我們都知道python有深拷貝和淺拷貝,但變量賦值又是什么機制呢?這是個容易被忽略卻又極易踩坑的點,下面我們來一探究竟,需要的朋友可以參考一下
    2022-02-02
  • Python詳細講解圖像處理的而兩種庫OpenCV和Pillow

    Python詳細講解圖像處理的而兩種庫OpenCV和Pillow

    這篇文章介紹了Python使用OpenCV與Pillow分別進行圖像處理的方法,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-06-06
  • 使用pandas實現(xiàn)連續(xù)數(shù)據(jù)的離散化處理方式(分箱操作)

    使用pandas實現(xiàn)連續(xù)數(shù)據(jù)的離散化處理方式(分箱操作)

    今天小編就為大家分享一篇使用pandas實現(xiàn)連續(xù)數(shù)據(jù)的離散化處理方式(分箱操作),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11
  • pyspark自定義UDAF函數(shù)調(diào)用報錯問題解決

    pyspark自定義UDAF函數(shù)調(diào)用報錯問題解決

    這篇文章主要為大家介紹了pyspark自定義UDAF函數(shù)調(diào)用報錯問題解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-06-06
  • pytorch 使用半精度模型部署的操作

    pytorch 使用半精度模型部署的操作

    這篇文章主要介紹了pytorch 使用半精度模型部署的操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-05-05
  • Python網(wǎng)絡爬蟲項目:內(nèi)容提取器的定義

    Python網(wǎng)絡爬蟲項目:內(nèi)容提取器的定義

    本篇文章主要介紹了Python網(wǎng)絡爬蟲項目,這能有效的節(jié)省程序員的時間,具有一定的參考價值,感興趣的小伙伴們可以參考一下。
    2016-10-10
  • Python創(chuàng)建7種不同的文件格式的方法總結

    Python創(chuàng)建7種不同的文件格式的方法總結

    今天的這篇文章呢,小編來介紹一下如何通過Python來創(chuàng)建各種形式的文件,這里包括了:文本文件、CSV文件、Excel文件、壓縮文件、XML文件、JSON文件和PDF文件,需要的可以參考一下
    2023-01-01
  • Python制作Windows按鍵通知腳本

    Python制作Windows按鍵通知腳本

    對于鍵盤沒有背光燈的同學而言,切換大小寫或控制Num鍵開關的時候沒有提示,經(jīng)常需要試探性地輸入一些字符來判斷開關是否打開,體驗非常糟糕。所以本文就來用Python做一個Windows按鍵通知腳本,需要的可以參考一下
    2022-11-11
  • Python使用pathlib進行文件系統(tǒng)操作

    Python使用pathlib進行文件系統(tǒng)操作

    pathlib?是?Python?的一個標準庫,它提供了一個面向對象的文件系統(tǒng)路徑操作接口,本文主要介紹了Python使用pathlib進行文件系統(tǒng)操作的相關知識,有需要的可以了解下
    2024-11-11
  • Python中列出目錄中的文件的五種方法小結

    Python中列出目錄中的文件的五種方法小結

    本文主要介紹了Python中列出目錄中的文件的五種方法小結,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-02-02

最新評論