flask log 输出到文件的问题

2021-06-12 13:54:07 +08:00
 zxCoder
from flask import Flask
import logging

app = Flask(__name__)

@app.route('/')
def hello_world():
    app.logger.error("hello")
    return 'Hello World!'

if __name__ == '__main__':
    handler = logging.FileHandler('flask.log', encoding='UTF-8')
    handler.setLevel(logging.DEBUG)
    logging_format = logging.Formatter(
        '%(asctime)s - %(levelname)s - %(filename)s - %(funcName)s - %(lineno)s - %(message)s')
    handler.setFormatter(logging_format)
    app.logger.addHandler(handler)
    app.run()
    app.logger.error("????")

启动后访问 127.0.0.1:5000/

app.logger.error("hello")这个日志打印了,但是没有按设定的格式,而且也找不到 flask.log 文件

659 次点击
所在节点    问与答
2 条回复
zeyexe
2021-06-12 15:01:37 +08:00
When you want to configure logging for your project, you should do it as soon as possible when the program starts.

https://flask.palletsprojects.com/en/2.0.x/logging/#basic-configuration

请尝试在 app = Flask(__name__) 之前配置日志。
johnsona
2021-06-12 17:55:36 +08:00
flask 有个 logger 属性 实际上是被 property 装饰的方法 创建对象的时候执行了 文档的建议是 你晚了就 remove 好像是的

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/783074

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX