logging模塊

来源:https://www.cnblogs.com/HZLS/archive/2019/01/15/10273667.html
-Advertisement-
Play Games

一 日誌級別: 二 預設級別為warning,預設列印到終端: 四 logging模塊的Formatter,Handler,Logger,Filter對象: 七 應用: ...


一 日誌級別:

CRITICAL = 50 #FATAL = CRITICAL
ERROR = 40
WARNING = 30 #WARN = WARNING
INFO = 20
DEBUG = 10
NOTSET = 0 #不設置

二 預設級別為warning,預設列印到終端:

import logging

logging.debug('調試debug')
logging.info('消息info')
logging.warning('警告warn')
logging.error('錯誤error')
logging.critical('嚴重critical')

'''
WARNING:root:警告warn
ERROR:root:錯誤error
CRITICAL:root:嚴重critical
'''

 

format參數中可能用到的格式化串:
%(name)s Logger的名字
%(levelno)s 數字形式的日誌級別
%(levelname)s 文本形式的日誌級別
%(pathname)s 調用日誌輸出函數的模塊的完整路徑名,可能沒有
%(filename)s 調用日誌輸出函數的模塊的文件名
%(module)s 調用日誌輸出函數的模塊名
%(funcName)s 調用日誌輸出函數的函數名
%(lineno)d 調用日誌輸出函數的語句所在的代碼行
%(created)f 當前時間,用UNIX標準的表示時間的浮 點數表示
%(relativeCreated)d 輸出日誌信息時的,自Logger創建以 來的毫秒數
%(asctime)s 字元串形式的當前時間。預設格式是 “2003-07-08 16:49:45,896”。逗號後面的是毫秒
%(thread)d 線程ID。可能沒有
%(threadName)s 線程名。可能沒有
%(process)d 進程ID。可能沒有
%(message)s用戶輸出的消息

 

#========使用
import logging
logging.basicConfig(filename='access.log',
                    format='%(asctime)s - %(name)s - %(levelname)s -%(module)s:  %(message)s',
                    datefmt='%Y-%m-%d %H:%M:%S %p',
                    level=10)

logging.debug('調試debug')
logging.info('消息info')
logging.warning('警告warn')
logging.error('錯誤error')
logging.critical('嚴重critical')





#========結果
access.log內容:
2017-07-28 20:32:17 PM - root - DEBUG -test:  調試debug
2017-07-28 20:32:17 PM - root - INFO -test:  消息info
2017-07-28 20:32:17 PM - root - WARNING -test:  警告warn
2017-07-28 20:32:17 PM - root - ERROR -test:  錯誤error
2017-07-28 20:32:17 PM - root - CRITICAL -test:  嚴重critical

 

四 logging模塊的Formatter,Handler,Logger,Filter對象:

#logger:產生日誌的對象

#Filter:過濾日誌的對象

#Handler:接收日誌然後控制列印到不同的地方,FileHandler用來列印到文件中,StreamHandler用來列印到終端

#Formatter對象:可以定製不同的日誌格式對象,然後綁定給不同的Handler對象使用,以此來控制不同的Handler的日誌格式


'''
critical=50
error =40
warning =30
info = 20
debug =10
'''


import logging

#1、logger對象:負責產生日誌,然後交給Filter過濾,然後交給不同的Handler輸出
logger=logging.getLogger(__file__)

#2、Filter對象:不常用,略

#3、Handler對象:接收logger傳來的日誌,然後控制輸出
h1=logging.FileHandler('t1.log') #列印到文件
h2=logging.FileHandler('t2.log') #列印到文件
h3=logging.StreamHandler() #列印到終端

#4、Formatter對象:日誌格式
formmater1=logging.Formatter('%(asctime)s - %(name)s - %(levelname)s -%(module)s:  %(message)s',
                    datefmt='%Y-%m-%d %H:%M:%S %p',)

formmater2=logging.Formatter('%(asctime)s :  %(message)s',
                    datefmt='%Y-%m-%d %H:%M:%S %p',)

formmater3=logging.Formatter('%(name)s %(message)s',)


#5、為Handler對象綁定格式
h1.setFormatter(formmater1)
h2.setFormatter(formmater2)
h3.setFormatter(formmater3)

#6、將Handler添加給logger並設置日誌級別
logger.addHandler(h1)
logger.addHandler(h2)
logger.addHandler(h3)
logger.setLevel(10)

#7、測試
logger.debug('debug')
logger.info('info')
logger.warning('warning')
logger.error('error')
logger.critical('critical')

七 應用:

 

'''# 定義三種日誌輸出格式 開始'''

standard_format = '[%(asctime)s][%(threadName)s:%(thread)d][task_id:%(name)s][%(filename)s:%(lineno)d]' \
                  '[%(levelname)s][%(message)s]' #其中name為getlogger指定的名字

simple_format = '[%(levelname)s][%(asctime)s][%(filename)s:%(lineno)d]%(message)s'

id_simple_format = '[%(levelname)s][%(asctime)s] %(message)s'

'''# 定義日誌輸出格式 結束'''

'''定義日誌文件的路徑'''
LOG_PATH=r'a3.log'



'''# log配置字典'''
LOGGING_DIC = {
    'version': 1,
    'disable_existing_loggers': False,
    'formatters': {
        'standard': {
            'format': standard_format
        },
        'simple': {
            'format': simple_format
        },
    },
    'filters': {},
    'handlers': {
        #列印到終端的日誌
        'console': {
            'level': 'DEBUG',
            'class': 'logging.StreamHandler',  # 列印到屏幕
            'formatter': 'simple'
        },
        #列印到文件的日誌,收集info及以上的日誌
        'default': {
            'level': 'DEBUG',
            'class': 'logging.handlers.RotatingFileHandler',  # 保存到文件
            'formatter': 'standard',
            'filename': LOG_PATH,  # 日誌文件
            'maxBytes': 1024*1024*5,  # 日誌大小 5M
            'backupCount': 5,
            'encoding': 'utf-8',  # 日誌文件的編碼,再也不用擔心中文log亂碼了
        },
    },
    'loggers': {
        #logging.getLogger(__name__)拿到的logger配置
        '': {
            'handlers': ['default', 'console'],  # 這裡把上面定義的兩個handler都加上,即log數據既寫入文件又列印到屏幕
            'level': 'DEBUG',
            'propagate': True,  # 向上(更高level的logger)傳遞
        },
    },
}



logging.config.dictConfig(LOGGING_DIC)  # 導入上面定義的logging配置
logger = logging.getLogger(__name__)  # 生成一個log實例
logger.debug('測試')  # 記錄該文件的運行狀態

  

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 先轉一篇介紹JSF的文章: Javaserver Faces 簡介 — 什麼是 JSF? 作者:Chris Schalk,Oracle Corporation2005 年 4 月 什麼是 JSF? JavaServer Faces (JSF) 是一種用於構建 Web 應用程式的新標準 Java 框架 ...
  • 在test.c中寫如下代碼: 1 #include <stdio.h> 2 3 int main() 4 { 5 printf("line:%d\n", lxx_line); 6 return 0; 7 } 使用gcc編譯 gcc -o test test.c 執行 ./test 結果 line:5 ...
  • 數字類型及操作 一、整數類型 (1)python中的整數與數學中的概念是一致的,可以正也可以負,沒有取值範圍。 pow(x,y)函數是計算x的y次冪,想計算多大就多大。 (2)在整數類型中有四種進位形式 十進位:1015, 99, -45 二進位:以0b或0B開頭:0b010,0B101 八進位:以 ...
  • 迭代器模式又稱游標模式,該模式可以順序訪問一個集合中元素而不必暴露集合內部對象。 在Java集合框架Collection中廣泛使用該模式來遍歷內部元素。所有熟悉java語言的應該都瞭解並應用過。 採用迭代器遍歷對象。 迭代器結構: 聚合對象(collection):存儲數據 迭代器:遍曆數據 例子: ...
  • pytorch初學者,想載入自己的數據,瞭解了一下數據類型、維度等信息,方便以後載入其他數據。 1 torchvision.transforms實現數據預處理 transforms.Totensor()操作必須要有,將數據轉為張量格式。 2 torch.utils.data.Dataset實現數據讀 ...
  • 題意 "題目鏈接" Sol 感覺這個思路還是不錯的 cpp include using namespace std; const int MAXN = 501, SS = 5e6 + 10; inline int read() { char c = getchar(); int x = 0, f = ...
  • class BookManager(models.Manager): # 改變查詢集的結果集 def all(self): books = super().all() # QuerySet books = books.filter(isDelete=False) return books # 封裝函... ...
  • 一、基本設置 1,應用註冊 若要把app應用顯示在後臺管理中,需要在admin.py中註冊。有兩種方式註冊 1.1 方式一: 1.2 方式二:用裝飾器 2,admin界面漢化 預設admin後臺管理界面是英文的,可以在settings.py中設置: LANGUAGE_CODE='zh-hans' T ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...