- 背景,在學習logging時總是遇到無法理解的問題,總結,嘗試一下更清晰明了了,讓我們開始吧!
-
logging模塊常用format格式說明
- %(levelno)s: 打印日志級別的數值
- %(levelname)s: 打印日志級別名稱
- %(pathname)s: 打印當前執行程序的路徑,其實就是sys.argv[0]
- %(filename)s: 打印當前執行程序名,python如:login.py
- %(funcName)s: 打印日志的當前函數
- %(lineno)d: 打印日志的當前行號,在第幾行打印的日志
- %(asctime)s: 打印日志的時間
- %(thread)d: 打印線程ID
- %(threadName)s: 打印線程名稱
- %(process)d: 打印進程ID
- %(message)s: 打印日志信息
-
使用前理解:
-
logging.basicConfig函數各參數:
-
filename: 指定日志文件名,如my.log 或my.txt
-
filemode: 和file函數意義相同,指定日志文件的打開模式, 'w'或'a'
- format: 指定輸出的格式和內容,format可以輸出很多有用信息,如下例所示:
- datefmt: 指定時間格式,同time.strftime()
- level: 設置日志級別,默認為logging.WARNING
- stream: 指定將日志的輸出流,可以指定輸出到sys.stderr,sys.stdout或者文件,默認輸出到sys.stderr,當stream和filename同時指定時,stream被忽略
-
logging中使用format:
例1:指定文件測試
logging.basicConfig(level=logging.DEBUG,
format='%(asctime)s %(filename)s [line:%(lineno)d] %(levelname)s %(message)s',
datefmt='%a, %d %b %Y %H:%M:%S',
filename='myapp.txt',
filemode='w')
logging.debug("這是一個debug")
執行結果:
例2:不指定文件,在窗口打印日志
logging.basicConfig(level=logging.DEBUG,
format='%(asctime)s %(thread)d %(threadName)s %(filename)s[line:%(lineno)d] %(levelname)s %(message)s',
datefmt='%a, %d %b %Y %H:%M:%S',
filemode='w')
執行結果: