日志管理 logging

日志级别,默认是waring

DEBUG 详细信息

INFO 正常运行产生的一些信息

WARNING 警告用户,虽然正常但可能会发生错误

ERROR 严重错误

CRITICAL 严重错误

简单应用

基础配置

python 复制代码
#filename,日志输出的文件,filemode='w',每次运行后会清除上次的日志内容,level=logging.DEBUG,表示只要在这个等级(包括)上的都会被输出
logging.basicConfig(filename='demo.log',filemode='w',level=logging.DEBUG)
logging.debug("debug message")
logging.info("info message")
logging.warning("warning message")
logging.error("error message")
logging.critical("critical message")

输出变量

python 复制代码
logging.basicConfig(level=logging.DEBUG)
logging.debug("姓名 %s,年龄 %d","张三",19)
logging.debug("姓名 %s,年龄 %d"%("张三",19))

设置输出格式

高级应用

loggers:记录器,提供应用程序代码直接使用的接口

Handlers:处理器,将日志输出到指定的位置

Filters:过滤器,更好选择输出的日志

Formatters:格式化器

python 复制代码
#记录器
logger = logging.getLogger("app_log")
logger.setLevel(logging.DEBUG)

#处理器
#输出控制台
consoleHandle = logging.StreamHandler()
consoleHandle.setLevel(logging.DEBUG)

#输出文件
fileHandle = logging.FileHandler(filename="addDemo.log")
fileHandle.setLevel(logging.INFO)

#formatter格式
formatter = logging.Formatter("%(asctime)s - %(name)s - %(levelname)s - %(message)s")

#设置处理的的输出格式
consoleHandle.setFormatter(formatter)
fileHandle.setFormatter(formatter)

#记录器要设置处理器
logger.addHandler(consoleHandle)
logger.addHandler(fileHandle)

#过滤器
flt = logging.Filter("cc")

#不会输出日志,被过滤掉
# logger.addFilter(flt)
#指定过滤对应的处理器
fileHandle.addFilter(flt)

logger.debug("debug message")
logger.info("info message")
logger.warning("warning message")
logger.error("error message")
logger.critical("critical message")

使用配置文件

配置文件

python 复制代码
[loggers]
keys=root,app_log

[handlers]
keys=fileHandler,consoleHandle

[formatters]
keys=simpleFormatter

[logger_root]
level=DEBUG
handlers=consoleHandle

[logger_app_log]
level=DEBUG
handlers=fileHandler,consoleHandle
qualname=app_log
propagate=0

[handler_consoleHandle]
class=StreamHandler
args=(sys.stdout,)
level=DEBUG

[handler_fileHandler]
class=handlers.TimedRotatingFileHandler
args=('app_log.log','midnight',1,0)
level=DEBUG
formatter=simpleFormatter

[formatter_simpleFormatter]
format=%(asctime)s|%(levelname)8s|%(filename)s[:%(lineno)d]|%(message)s
datefmt=%Y-%m-%d %H:%M:%S
python 复制代码
#配置文件方式处理日志
logging.config.fileConfig('logging.conf')
#记录器
rootLogger = logging.getLogger()
logger = logging.getLogger("app_log.log")

a="sss"
try:
    int(a)
except Exception as e:
    logger.exception(e)


logger.debug("debug message")
logger.info("info message")
logger.warning("warning message")
logger.error("error message")
logger.critical("critical message")
相关推荐
unicrom_深圳市由你创科技7 小时前
C# 如何实现对象序列化
开发语言·c#
夜珀7 小时前
AtomGit算力连接与实战全攻略
开发语言·人工智能
xyq20248 小时前
SQLite 命令详解
开发语言
xinhuanjieyi8 小时前
php setplayersjson实现类型转换和文件锁定机制应对高并发
android·开发语言·php
高冷的上官梓芸8 小时前
【A15】默认关闭屏保
java
爱学习的小囧8 小时前
嵌套式 ESXi 8.x/9.0 虚拟设备下载与实战指南
java·linux·运维·服务器·虚拟化
前端 贾公子8 小时前
uniapp中@input修改input内容不生效 | 过滤赋值无效 | 连续非法字符不更新的问题
开发语言·前端·javascript
五阿哥永琪8 小时前
从零读懂 Java 函数式接口:Function、Consumer、Supplier、Predicate
java·开发语言
533_8 小时前
[vxe-table] 表头:点击出现输入框
android·java·javascript