参照博客https://www.cnblogs.com/meloncodezhang/p/11922804.html
1 这是我的目录

1 config /config.py
import logging
class Config(object):
# 设置日志等级
LOG_LEVEL = logging.DEBUG
class DevelopConfig(Config):
"""开发环境下的配置"""
DEBUG = True
class ProductConfig(Config):
"""生成环境下的配置"""
DEBUG = False
LOG_LEVEL = logging.WARNING
class TestConfig(Config):
"""测试环境下的配置"""
DEBUG = True
TESTING = True
config = {
"development": DevelopConfig,
"production": ProductConfig,
"testing": TestConfig,
}
2 log/log.py
import logging
from logging.handlers import RotatingFileHandler
from flask import Flask
from config.config import config
def setup_log(config_name):
"""
:param config_name: 传入日志等级
:return:
"""
# 设置日志的的登记
logging.basicConfig(level=config[config_name].LOG_LEVEL)
# 创建日志记录器,设置日志的保存路径和每个日志的大小和日志的总大小
file_log_handler = RotatingFileHandler("log/log.log", maxBytes=1024*1024*100,backupCount=100, encoding='utf-8')
# 创建日志记录格式,日志等级,输出日志的文件名 行数 日志信息
formatter = logging.Formatter("%(levelname)s %(filename)s: %(lineno)d %(message)s")
# 为日志记录器设置记录格式
file_log_handler.setFormatter(formatter)
# 为全局的日志工具对象(flaks app使用的)加载日志记录器
logging.getLogger().addHandler(file_log_handler)
def create_app(config_name):
"""
:param config_name: info bug error
:return:
"""
# 创建app实例前先配置好日志文件
setup_log(config_name)
# 创建app实例对象
app = Flask(__name__)
# 实例对象从配置文件中加载配置
app.secret_key = 'wertyui234567gf!@#$%^&*('
from flask_cors import CORS # 跨域
CORS(app, supports_credentials=True)
app.config.from_object(config[config_name]) # 这里直接拿到的是类的名字,也就是引用
return app
3 主目录文件app
from log.log import create_app, setup_log #配置日志
from config.config import Config
import logging
from flask import Flask, views, render_template, send_file, request, session,current_app
app = create_app("development")
4 测试
@app.route("/")
def index():
logging.debug("测试打印日志")
# logging.warning("测试打印日志")
# logging.error("测试打印日志")
return "index page"
