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

python利用logging模塊實現(xiàn)根據(jù)日志級別打印不同顏色日志的代碼案例

 更新時間:2022年12月01日 08:43:25   作者:eliwang  
這篇文章主要介紹了python利用logging模塊實現(xiàn)根據(jù)日志級別打印不同顏色日志,本文通過實例代碼給大家詳細(xì)講解,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下

logger:日志器對象,可通過logging.getLogger()方法獲取

handler:處理器對象,將日志信息輸出到指定位置,可通過logger.addHandler()方法進(jìn)行添加

formatter:格式器對象,輸出格式化日志字符串

有時候同一個應(yīng)用程序有不同的日志需求,比如將error級別的日志在控制臺輸出,critical級別的日志寫入日志文件中,這就需要不同的handler來實現(xiàn),然后均通過logger.addHandler()方法進(jìn)行添加

代碼:

# coding:utf-8
import logging
import colorlog
class Log:
    def __init__(self,name=None,log_level=logging.DEBUG):
        # 獲取logger對象
        self.logger = logging.getLogger(name)

        # 避免重復(fù)打印日志
        self.logger.handlers = []

        # 指定最低日志級別:(critical > error > warning > info > debug)
        self.logger.setLevel(log_level)

        # 日志格化字符串
        console_fmt = '%(log_color)s%(asctime)s-%(threadName)s-%(filename)s-[line:%(lineno)d]-%(levelname)s: %(message)s'
        file_fmt = '%(asctime)s-%(threadName)s-%(filename)s-[line:%(lineno)d]-%(levelname)s: %(message)s'

        # 控制臺輸出不同級別日志顏色設(shè)置
        color_config = {
            'DEBUG': 'cyan',
            'INFO': 'green',
            'WARNING': 'yellow',
            'ERROR': 'red',
            'CRITICAL': 'purple',
        }

        console_formatter = colorlog.ColoredFormatter(fmt=console_fmt,log_colors=color_config)
        file_formatter = logging.Formatter(fmt=file_fmt)

        # 輸出到控制臺
        console_handler = logging.StreamHandler()
        # 輸出到文件
        file_handler = logging.FileHandler(filename=name,mode='a',encoding='utf-8')

        # 設(shè)置日志格式
        console_handler.setFormatter(console_formatter)
        file_handler.setFormatter(file_formatter)

        # 處理器設(shè)置日志級別,不同處理器可各自設(shè)置級別,默認(rèn)使用logger日志級別
        # console_handler.setLevel(logging.WARNING)
        file_handler.setLevel(logging.ERROR) # 只有error和critical級別才會寫入日志文件

        # logger添加處理器
        self.logger.addHandler(console_handler)
        self.logger.addHandler(file_handler)

    def debug(self,message):
        self.logger.debug(message)

    def info(self,message):
        self.logger.info(message)

    def warning(self,message):
        self.logger.warning(message)

    def error(self,message):
        self.logger.error(message)

    def critical(self,message):
        self.logger.critical(message)

if __name__ == '__main__':
    # 控制臺只會顯示warning及以上級別日志信息,而log.txt文件中則會記錄error及以上級別日志信息
    log = Log(name='log.txt',log_level=logging.WARNING)
    log.debug('debug')
    log.info('info')
    log.warning('warning')
    log.error('error')
    log.critical('critical')

最終控制臺按照指定顏色輸出warning以上級別日志內(nèi)容:

log.txt文件中寫入了error及critical級別日志內(nèi)容:

補充(python自帶的格式化字符串):

到此這篇關(guān)于python利用logging模塊實現(xiàn)根據(jù)日志級別打印不同顏色日志的文章就介紹到這了,更多相關(guān)python logging模塊打印不同顏色日志內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • python re庫的正則表達(dá)式入門學(xué)習(xí)教程

    python re庫的正則表達(dá)式入門學(xué)習(xí)教程

    這篇文章主要給大家介紹了關(guān)于python re庫的正則表達(dá)式的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者使用python具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03
  • django框架model orM使用字典作為參數(shù),保存數(shù)據(jù)的方法分析

    django框架model orM使用字典作為參數(shù),保存數(shù)據(jù)的方法分析

    這篇文章主要介紹了django框架model orM使用字典作為參數(shù),保存數(shù)據(jù)的方法,結(jié)合實例形式分析了字典參數(shù)結(jié)合django model實現(xiàn)保存數(shù)據(jù)相關(guān)操作技巧,需要的朋友可以參考下
    2019-06-06
  • python編寫函數(shù)注意事項總結(jié)

    python編寫函數(shù)注意事項總結(jié)

    在本篇文章里小編給大家分享了一篇關(guān)于python編寫函數(shù)注意事項總結(jié)內(nèi)容,有需要的朋友們可以學(xué)習(xí)下。
    2021-03-03
  • Python讀取配置文件-ConfigParser的二次封裝方法

    Python讀取配置文件-ConfigParser的二次封裝方法

    這篇文章主要介紹了Python讀取配置文件-ConfigParser的二次封裝方法,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-02-02
  • Python實現(xiàn)自定義異常堆棧信息的示例代碼

    Python實現(xiàn)自定義異常堆棧信息的示例代碼

    當(dāng)我們的程序報錯時,解釋器會將整個異常的堆棧信息全部輸出出來。解釋器會將異常產(chǎn)生的整個調(diào)用鏈都給打印出來,那么問題來了,我們能不能自定義這些報錯信息呢?本文就來為大家詳細(xì)講講
    2022-07-07
  • Django REST framework內(nèi)置路由用法

    Django REST framework內(nèi)置路由用法

    這篇文章主要介紹了Django REST framework內(nèi)置路由用法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-07-07
  • django實現(xiàn)支付寶支付實例講解

    django實現(xiàn)支付寶支付實例講解

    在本篇文章里小編給大家整理的是一篇關(guān)于django支付寶支付的代碼實例內(nèi)容,需要的朋友們可以學(xué)習(xí)下。
    2019-10-10
  • 最新解決'nvidia-smi' 不是內(nèi)部或外部命令也不是可運行的程序

    最新解決'nvidia-smi' 不是內(nèi)部或外部命令也不是可運行的程序

    使用cmd查看電腦顯卡的信息,調(diào)用nvidia-smi查看顯卡使用情況報錯,提示'nvidia-smi' 不是內(nèi)部或外部命令,也不是可運行的程序,本文給大家分享完美解決方案,感興趣的朋友跟隨小編一起看看吧
    2023-01-01
  • Python網(wǎng)絡(luò)編程使用select實現(xiàn)socket全雙工異步通信功能示例

    Python網(wǎng)絡(luò)編程使用select實現(xiàn)socket全雙工異步通信功能示例

    這篇文章主要介紹了Python網(wǎng)絡(luò)編程使用select實現(xiàn)socket全雙工異步通信功能,簡單說明了select模塊的功能及socket全雙工異步通信功能的相關(guān)實現(xiàn)技巧,需要的朋友可以參考下
    2018-04-04
  • python3解析庫pyquery的深入講解

    python3解析庫pyquery的深入講解

    做過前端開發(fā)的同志都應(yīng)該知道或了解過jquery,jQuery 是一個用來處理DOM的JavaScript庫。pyquery說白了就是jquery的Python版本。下面這篇文章主要給大家介紹了關(guān)于python3解析庫pyquery的相關(guān)資料,需要的朋友可以參考下
    2018-06-06

最新評論