1. 项目中,日志和配置文件都是单独在一个文件夹中,一般log文件夹和config文件夹,两个文件夹和manage.py在同一个目录下。

2. 配置日志前,先给flask装上script脚本扩展,Flask 1.1.1 版本

from flask.ext.script import Manager
# 报错 no module named flask.ext
解决办法:from flask_script import Manager 网上说是新版flask推荐这种方式导入扩展包
# 继续报错:no module named flask_script
解决办法:pip install flask_script
# 继续报错: ModuleNotFoundError: No module named 'setuptools'
----------------------------------------
ERROR: Command errored out with exit status 1: python setup.py egg_info Check the logs for full command output.
# 分析,原来是 没有安装 setuptools # 安装 setuptools
pip install setuptools # pip install flask_script # 然后解决问题 from flask_script import Manager

用Manager来管理app

manage.py

from logs.logs import create_app, setup_log
from flask import url_for,redirect
from flask_script import Manager
from config.config import Config
import logging app = create_app("development") # 这里通过一个函数创建了app的实例对象
manage = Manager(app) # 创建Manager的实例对象,参数是app对象
@app.route("/")
def index():
logging.debug("测试打印日志")
# logging.warning("测试打印日志")
# logging.error("测试打印日志")
return "index page" # 传递路径参数,通过视图函数的形参传递
@app.route("/hello/<username>")
def hello(username):
logging.debug(username)
return "hello page" + username # 转换器:可以将传递的参数进行类型转换
@app.route("/user/<int:p_id>")
def converter_int(p_id):
logging.warning(str(p_id))
return "p_id: " + str(p_id) # 构建url
@app.route("/new")
def make_url():
"""
url_for(视图函数的名字,链接后面的参数)
:return:
"""
new_url = url_for('hello', username="zhangyanyan")
print(new_url)
return redirect(new_url) if __name__ == '__main__':
manage.run() 启动方式变成:manage.py目录下,python manage.py runserver 启动项目

logs/logs.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("logs/log", maxBytes=1024*1024*100,backupCount=100)
# 创建日志记录格式,日志等级,输出日志的文件名 行数 日志信息
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.config.from_object(config[config_name]) # 这里直接拿到的是类的名字,也就是引用
return app

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,
}

logs/log文件

INFO _internal.py: 122  * Running on http://127.0.0.1:5000/ (Press CTRL+C to quit)
INFO _internal.py: 122 * Restarting with stat
WARNING _internal.py: 122 * Debugger is active!
INFO _internal.py: 122 * Debugger PIN: 340-059-688
DEBUG manage.py: 13 测试打印日志
WARNING manage.py: 14 测试打印日志
ERROR manage.py: 15 测试打印日志
INFO _internal.py: 122 127.0.0.1 - - [24/Nov/2019 15:10:29] "GET / HTTP/1.1" 200 -
INFO _internal.py: 122 * Detected change in '/Users/xxx/PycharmProjects/flask_project1/manage.py', reloading
INFO _internal.py: 122 * Restarting with stat
WARNING _internal.py: 122 * Debugger is active!
INFO _internal.py: 122 * Debugger PIN: 340-059-688
DEBUG manage.py: 22 zhang
INFO _internal.py: 122 127.0.0.1 - - [24/Nov/2019 15:12:01] "GET /hello/zhang HTTP/1.1" 200 -
INFO _internal.py: 122 * Detected change in '/Users/xxx/PycharmProjects/flask_project1/manage.py', reloading
INFO _internal.py: 122 * Restarting with stat
WARNING _internal.py: 122 * Debugger is active!
INFO _internal.py: 122 * Debugger PIN: 340-059-688

config.py中还可以进行好多的配置

例如:数据库的配置,密码的配置

具体的配置参看:https://www.cnblogs.com/alicelai1319/p/10289798.html

最新文章

  1. 。。。学习CSS3的第一个属性border-radius。。。
  2. 关于Java的基本类型
  3. MySQL学习笔记——ERROR 1045 (28000): Access denied for user &#39;root&#39;@&#39;localhost&#39; (using password: NO)
  4. POJ 3260 多重背包+完全背包
  5. 最长回文子串(Longest Palindromic Substring)-DP问题
  6. Ubuntu上部署C# 网站 步骤简单记录
  7. HDOJ(HDU) 2156 分数矩阵(嗯、求和)
  8. 国内外DNS服务器地址列表
  9. vs 2013下自定义ASP.net MVC 5/Web API 2 模板(T4 视图模板/控制器模板)
  10. Java 集合之LinkedList源码分析
  11. alias,data,系统定时开关机的基本操作
  12. es6 Symbol类型
  13. cached_property的使用
  14. gensim自然语言处理
  15. css 優先級
  16. Python类的私有属性
  17. 详解BOM用途分类及在汽车企业中的应用
  18. hyperledge vagrant docker development environment
  19. MySQL Workbench中如何开启MySQL的远程帐号
  20. 批处理系列(14) - 路径/时间/字符切分等DEMO操作

热门文章

  1. mysql执行拉链表操作
  2. JS - defer 和 async
  3. leetcode 342. 4的幂(python)
  4. centos官网镜像下载方法
  5. 算法初级(scala)
  6. [19/06/08-星期六] CSS基础_表格&amp;表单
  7. Python3 AES加解密(AES/ECB/PKCS5Padding)
  8. 用了 10 多年的 Tomcat 居然有bug !
  9. glVertexAttribPointer 顶点数据解析方式
  10. css是干什么的