天天看點

Python 日志以及logging子產品的使用

關于Python中如何使用日志,使用logging子產品

import logging

# 錯誤類型的等級大于等于30的将會被記錄
logger = logging.basicConfig(filename='loger.log',
                             filemode='a',
                             format='%(asctime)s-%(name)s-%(levelname)s-%(module)s: %(message)s',
                             datefmt='%Y-%m-%d %H:%M:%S',
                             level=30)
                             
"""
filename 檔案儲存的路徑
filemade 以追加寫格式 
format 格式化儲存到檔案的字元串
datefmt 用來格式化'asctime'的時間格式
level 錯誤類型的級别,大于等于的将會被記錄
"""

"""
錯誤類型,以及級别
CRITICAL = 50
FATAL = CRITICAL
ERROR = 40
WARNING = 30
WARN = WARNING
INFO = 20
DEBUG = 10
"""

logging.critical('error')
logging.error('error')
logging.warning('error')
logging.info('error')
logging.debug('error')


# loger.log檔案中的記錄
2020-07-20 20:46:10-root-CRITICAL-loger: error
2020-07-20 20:46:10-root-ERROR-loger: error
2020-07-20 20:46:10-root-WARNING-loger: error
           

由于上面這種錯誤記錄隻能知道代碼中有錯誤,但并不知道具體是哪一行,是以還得自己去挨個找,是以下面将使用更優質的方法,traceback子產品

import logging
import traceback

logger = logging.baseConfig(filename='loger.log',
                             filemode='a',
                             format='%(asctime)s-%(name)s-%(levelname)s-%(module)s: %(message)s',
                             datefmt='%Y-%m-%d %H:%M:%S',
                             level=30)

def run():
	try:
		a += 1
	except NameError:
		msg = traceback.format_exc()
		logging.error(msg)

run()

# loger檔案中的記錄(執行了兩次)
# 下面的line與這裡的不對應是我的py檔案中還有其他的,是以顯示的與這裡的不對應。
2020-07-20 20:51:44-root-ERROR-loger: Traceback (most recent call last):
  File "E:/pyMysql/day/loger.py", line 28, in run
    b = a + 1
NameError: name 'a' is not defined

2020-07-20 20:51:53-root-ERROR-loger: Traceback (most recent call last):
  File "E:/pyMysql/day/loger.py", line 28, in run
    b = a + 1
NameError: name 'a' is not defined
           

這種方法可以記錄錯誤類型并且具體到某一行,更友善我們查找。