Python 日志模块logging

  • 原创
  • Madman
  • /
  • /
  • 0
  • 9708 次阅读

Synopsis: Python程序中可以使用内置的logging模块,方便的记录运行日志,将日志信息进行分类存储,当程序出现BUG时,可以通过分析日志来定位问题所在

1. 基本概念

import logging


logging.basicConfig(format='%(asctime)s - %(name)s - %(levelname)s - %(message)s')

logging.debug('This is debug message')
logging.info('This is info message')
logging.warning('This is warning message')
logging.error('This is error message')
logging.critical('This is critical message')

输出结果:

2018-06-27 15:21:37,941 - root - WARNING - This is warning message
2018-06-27 15:21:37,941 - root - ERROR - This is error message
2018-06-27 15:21:37,942 - root - CRITICAL - This is critical message

其中,2018-06-27 15:21:37,941对应%(asctime)s,表示当前时间;root对应%(name)s,表示logger实例的名称,默认名称是root;WARNING对应%(levelname)s,表示日志级别(可以看到默认是WARNING,它以下的INFO和DEBUG都不显示);This is warning message对应%(message)s,表示用户要输出的日志内容

1.1 日志级别

级别Level 对应数值
logging.NOTSET 0
logging.DEBUG 10
logging.INFO 20
logging.WARNING (默认级别) 30
logging.ERROR 40
logging.CRITICAL 50
In [1]: import logging

In [2]: logging.NOTSET
Out[2]: 0

In [3]: logging.DEBUG
Out[3]: 10

In [4]: logging.INFO
Out[4]: 20

In [5]: logging.WARNING
Out[5]: 30

In [6]: logging.ERROR
Out[6]: 40

In [7]: logging.CRITICAL
Out[7]: 50

如本文开头示例,默认日志级别是WARNING,它以下的INFODEBUG都不显示。

假设设置了日志级别为INFO,则会输出级别大于或等于INOF的日志,而小于它的如DEBUG则不会输出:

import logging


logging.basicConfig(format='%(asctime)s - %(name)s - %(levelname)s - %(message)s', level=logging.INFO)

logging.debug('This is debug message')
logging.info('This is info message')
logging.warning('This is warning message')
logging.error('This is error message')
logging.critical('This is critical message')

输出结果:

2018-06-27 15:39:15,582 - root - INFO - This is info message
2018-06-27 15:39:15,583 - root - WARNING - This is warning message
2018-06-27 15:39:15,
                                
                            
  • Miao jingjing
  • jackleek
  • raojingpeng
  • __豆约翰__
  • Congratulations you've made easy money cx180165.tw1.ru HD
  • Update the app for free money cx180165.tw1.ru QK
  • Gather Your Incentive Payment fdjhgkhjkg.temp.swtest.ru Bi
  • Unlock Hassle Free Dividend Payouts cx180165.tw1.ru lI
  • Get Compensated for Casual Jobs cv505813.tw1.ru xp
  • Easy money has been added to your account cx180165.tw1.ru 8H
  • Show your like get paid cx180165.tw1.ru RZ
  • Claim the funds reserved for members cv505813.tw1.ru E3
  • Secure Your Financial Bonus Right Now cx180165.tw1.ru Cw
  • Unlock Prizes by Maintaining Activity cx180165.tw1.ru Vg
  • Press here to access your money now cv505813.tw1.ru g3
  • Earn money by posting content cx180165.tw1.ru 7u
  • Acquire a Cash Award Instantly fdjhgkhjkg.temp.swtest.ru k6
  • Money is Deposited Directly into Your Hands cx180165.tw1.ru 9D
  • An instant cash prize is yours to claim cv505813.tw1.ru vV
  • Share your link earn cash fdjhgkhjkg.temp.swtest.ru I5
  • Gain an Immediate Monetary Award cx180165.tw1.ru Sk
  • Win and See Cash Deposited Now cv505813.tw1.ru du
  • Your cash win is just seconds away cx180165.tw1.ru MB
  • Don't lose out on your recovered cash cx180165.tw1.ru tR
未经允许不得转载: LIFE & SHARE - 王颜公子 » Python 日志模块logging

分享

作者

作者头像

Madman

如需 Linux / Python 相关问题付费解答,请按如下方式联系我

0 条评论

暂时还没有评论.

专题系列