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

这种方法可以记录错误类型并且具体到某一行,更方便我们查找。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值