Flask - 日志

本文介绍了如何在Python中使用logging模块配置和管理日志,包括创建logger、设置日志级别、添加handler及formatter。同时展示了如何在Flask应用中集成日志,通过app.logger进行操作,并修改默认logger名称。示例代码详细演示了如何将日志记录到文件,并提供了两种不同的配置方式。
摘要由CSDN通过智能技术生成

logger

  • 大多数情况下,正常地返回 400 Bad Request 就可以了,但是有时候不能这么做,并且要让代码继续运行。
  • 调用日志记录的例子 :
app.logger.debug('A value for debugging')
app.logger.warning('A warning occurred (%d apples)', 42)
app.logger.error('An error occurred')

修改默认的logger的名字

  • app.logger.name = ‘’

python的logging模块

  • 配置方式一
import logging

# 第一步,创建一个logger
logger = logging.getLogger()
logger.setLevel(logging.INFO)  # Log等级总开关
handler = logging.FileHandler("log1.txt", mode='w')
handler.setLevel(logging.DEBUG)  # 输出到file的log等级的开关
# 第三步,定义handler的输出格式
formatter = logging.Formatter("%(asctime)s - %(filename)s[line:%(lineno)d] - %(levelname)s: %(message)s")
handler.setFormatter(formatter)
# 第四步,将logger添加到handler里面
logger.addHandler(handler)
# 日志
logger.debug('this is a logger debug message')
logger.info('this is a logger info message')
logger.warning('this is a logger warning message')
logger.error('this is a logger error message')
logger.critical('this is a logger critical message')
  • 配置方式二
logging.basicConfig(filename="login.txt", filemode='a', level=logging.INFO,
                    format='%(asctime)s - %(name)s - %(levelname)s - %(message)s')
logger = logging.getLogger(__name__)

logger和flask结合使用

import logging
from flask import Flask, request, render_template, flash

app = Flask(__name__)
app.config['SECRET_KEY'] = 'asdfghj'

logging.basicConfig(filename="login.txt", filemode='a', level=logging.INFO,
                    format='%(asctime)s - %(name)s - %(levelname)s - %(message)s')
logger = logging.getLogger("app")


@app.route('/index')
def index():
    app.logger.warning("首页警告")
    return render_template('index.html')
  • 如果想让app.logger.warning写到文件. logging.getLogger() 必须起名为app
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值