日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > python >内容正文

python

【Python】logging内置模块基本使用

發布時間:2025/3/15 python 21 豆豆
生活随笔 收集整理的這篇文章主要介紹了 【Python】logging内置模块基本使用 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

logging模塊是Python內置的標準模塊,主要用于輸出運行日志,可以設置輸出日志的等級、日志保存路徑、日志文件回滾等。
print也可以輸入日志,logging相對print來說更好控制輸出在哪個地方,怎么輸出及控制消息級別來過濾掉那些不需要的信息。
一條日志信息對應的是一個事件的發生,而一個事件通常需要包括以下幾個內容:
事件發生時間
事件發生位置
事件的嚴重程度--日志級別
事件內容
上面這些都是一條日志記錄中可能包含的字段信息,當然還可以包括一些其他信息,如進程ID、進程名稱、線程ID、線程名稱等。
日志格式就是用來定義一條日志記錄中包含那些字段的,且日志格式通常都是可以自定義的。

''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''' #作者:cacho_37967865 #博客:https://blog.csdn.net/sinat_37967865 #文件:loggingModel.py #日期:2018-11-12 #備注:logging模塊是Python內置的標準模塊,主要用于輸出運行日志,可以設置輸出日志的等級、日志保存路徑、日志文件回滾等。 '''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''import logging from datetime import datetime import oslogger = logging.getLogger() # 初始化一個logger# 默認生成的root logger的level是logging.WARNING,低于該級別的就不輸出了 # 級別排序:CRITICAL>ERROR>WARNING>INFO>DEBUG logger.setLevel(logging.DEBUG) # 總級別:所有信息都輸出# 將日志存儲到指定目錄的文件 file_name = datetime.now().strftime('%Y%m%d%H%M') # 用時間當成文件名稱,格式:201811111833(年月日時分) log_path = os.path.dirname(os.path.abspath('.')) + '/logs/' # 指定存儲的絕對路徑 log_name = log_path + file_name + '.log' # 生成文件信息 save_file = logging.FileHandler(log_name)# 在控制臺輸出日志 output = logging.StreamHandler() output.setLevel(logging.INFO) # 設置輸出到控制臺的級別# 日志輸出格式設置 formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s --> %(message)s') save_file.setFormatter(formatter) output.setFormatter(formatter)# 日志處理 logger.addHandler(save_file) logger.addHandler(output)logger.debug("this is a logger debug message") logger.info("this is a logger info message") logger.warning("this is a logger warning message") logger.error("this is a logger error message") logger.critical("this is a logger critical message")

一、日志級別:

默認生成的root logger的level是logging.WARNING,低于該級別的就不輸出了
級別排序:CRITICAL > ERROR > WARNING > INFO > DEBUG
debug : 打印全部的日志,詳細的信息,通常只出現在診斷問題上
info : 打印info,warning,error,critical級別的日志,確認一切按預期運行
warning : 打印warning,error,critical級別的日志,一個跡象表明,一些意想不到的事情發生了,或表明一些問題在不久的將來(例如。磁盤空間低”),這個軟件還能按預期工作
error : 打印error,critical級別的日志,更嚴重的問題,軟件沒能執行一些功能
critical : 打印critical級別,一個嚴重的錯誤,這表明程序本身可能無法繼續運行

二、常用函數:

logging.getLogger() 初始化一個logger
Logger.setLevel() ??設置總日志級別
logger.addHandler() 日志處理
logging.FileHandler() ??日志存儲到文件
logging.StreamHandler() 日志輸出到控制臺
logging.Formatter() ????日志格式
setFormatter() ?????設置日志格式
setLevel() ? ? ? ? ?設置具體日志級別

三、format常用格式說明

%(asctime)s: 打印日志的時間
%(name)s: 打印模塊名稱
%(levelname)s: 打印日志級別名稱
%(message)s: 打印日志信息

%(levelno)s: 打印日志級別的數值
%(pathname)s: 打印當前執行程序的路徑,其實就是sys.argv[0]
%(filename)s: 打印當前執行程序名
%(funcName)s: 打印日志的當前函數
%(lineno)d: 打印日志的當前行號
%(thread)d: 打印線程ID
%(threadName)s: 打印線程名稱
%(process)d: 打印進程ID

總結

以上是生活随笔為你收集整理的【Python】logging内置模块基本使用的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。