Flask第五篇——设置debug模式
flask默认是没有开启debug模式的,开启debug模式有很多好处:
第一,可以帮助我们查找代码里面的错误,比如:
# coding: utf-8
from flask import Flask
# __name__是用来确定flask运行的主文件
app = Flask(__name__)
@app.route('/')
def hello_world():
x = 10
y = 0
res = x/y
print res
return 'Hello World!'
if __name__ == '__main__':
app.run()
我们都知道,除数是不能为0的,但是上面的代码里y的值是0,我们运行这段代码,然后去地址查看,只能看到内部服务错误,但是没有任何错误原因的说明,我们找起原因就会非常费劲:
除了方便找到bug以外,还有另一个原因促使我们开启debug模式,就是如果我们不开启debug模式,我们修改了上面代码里y的值不等于0,然后ctrl+s保存代码,去页面刷新页面仍然是上图,也就是说Ctrl+s没有重新加载代码的运行,如果我们每次修改代码都要重新运行代码才能看到结果,是不是非常的不方便呢?以上两个原因,让我们需要开启debug模式:
开启debug模式只需要我们加一句app.debug = True即可。重新运行代码以后我们发现控制台输出的内容也和之前不一样了,系统会提示你重启了服务并且开启了debug模式。
现在去刷新页面,会发现页面提示了我们报错的原因:
而且在报错的最下面可以看到代码报错的位置和原因:
现在我们来说一下控制台输出的最后一行的PIN码:
我们先来到报错页面代码报错的位置,将鼠标放在报错语句上会看到后面有一个命令行样子的图标:
现在点击那个图标:
会发现页面弹出了这么一个框:
上面说着(翻译):控制台被锁定,需要输入PIN来解锁。PIN已经在你运行服务(就是你的代码)的shell(就是工具,我们用的是pychram)标准输出里打印出来了,你可以在那里找到它。
我们把PIN码粘贴过去就能看到:
我们可以直接在这里调试了,我们需要看一下y的值是不是真的是0,我们print y一下:
这样就快速的定位到了问题的所在了。而且这个PIN值是不需要你每次都输入的,你只要输入一次,8小时以内都不需要再次输入的,因为flask会生成一个cookie信息,记录你的登录状态。
当然开启debug模式并不是只有上面一种方式:
app.run(debug=True)
# coding: utf-8
from flask import Flask
# __name__是用来确定flask运行的主文件
app = Flask(__name__)
# 开启debug模式方法一
# app.debug = True
@app.route('/')
def hello_world():
x = 10
y = 0
res = x/y
print res
return 'Hello World!'
if __name__ == '__main__':
# 开启debug模式方法二
app.run(debug=True)
第三种开启debug的方法是通过配置文件
app.config.update(DEBUG=True)
注意Debug必须要大写哦
# coding: utf-8
from flask import Flask
# __name__是用来确定flask运行的主文件
app = Flask(__name__)
app.config.update(DEBUG=True)
@app.route('/')
def hello_world():
x = 10
y = 0
res = x/y
print res
return 'Hello World!'
if __name__ == '__main__':
app.run()
第四种开启方式——加载文件
我们新建一个名为configs的py文件,内面写:
# coding: utf-8
DEBUG = True
然后在代码里先导入import configs再引用这个文件
app.config.from_object(configs)Ctrl+s保存就会看到设置生效了:
代码如下:
# coding: utf-8
from flask import Flask
import configs
# __name__是用来确定flask运行的主文件
app = Flask(__name__)
app.config.from_object(configs)
@app.route('/')
def hello_world():
x = 10
y = 0
res = x/y
print res
return 'Hello World!'
if __name__ == '__main__':
app.run()
此外,如果你不导入import configsconfigs文件想用配置,那你也可以将上面代码里的app.config.from_object(configs)修改为
app.config.from_object('configs')就是加个引号,这样也是可以的:
虽然方式有这么多,但是我们还是习惯第一种最简单直接的方式——
app.debug=True。
微信公众号搜索“自动化测试实战”或扫描下方二维码添加关注~~~

Flask第五篇——设置debug模式的更多相关文章
- Flask最强攻略 - 跟DragonFire学Flask - 第五篇 做一个用户登录之后查看学员信息的小例子
需求: 1. 用户名: oldboy 密码: oldboy123 2. 用户登录成功之后跳转到列表页面 3. 失败有消息提示,重新登录 4.点击学生名称之后,可以看到学生的详细信息 后端: from ...
- flask 第五篇
需求: 1. 用户名: oldboy 密码: oldboy123 2. 用户登录成功之后跳转到列表页面 3. 失败有消息提示,重新登录 4.点击学生名称之后,可以看到学生的详细信息 后端: from ...
- Nexus6P 设置Debug模式
一劳永逸,设置手机进入Debug模式实现完美Root 使用mkbootimg进行boot.ing编辑 将修改的系统官方Rom包中的boot.ing和mkbooting工具中的mkboot.mkboot ...
- Linux下Tomcat启动设置debug模式启动
原文: https://blog.csdn.net/li295214001/article/details/42077247 https://blog.csdn.net/jackie_xiaonan/ ...
- tomcat设置debug模式
1.设置 编辑catalina.bat,在 rem Guess CATALINA_HOME if not definedset "CURRENT_DIR=%cd%"if not & ...
- 在.net中设置debug模式预设代码
#region DEBUG #if DEBUG this.WorkOrgID.Value = "4DC4507E-434D-4EEB-967E-1E5CC28AA0C1"; thi ...
- springboot第四篇:debug模式开发运用
前提:项目是以maven project结构建立的,现状是无法进行断点调试的.怎么才能在eclipse里进行调试呢? 需要:①将项目打包部署到tomcat ②往项目加入dynamic web modu ...
- flask学习(四):debug模式
一. 设置debug模式 1. flask 1.0之前 在app.run()中传入一个关键字参数debug,app.run(debug=True),就设置当前项目为debug模式 2. flask 1 ...
- Flask(6)- debug 模式
使用 Flask 开发过程中存在两个常见的问题 当 Flask 程序出错时,没有提示错误的详细信息 修改 Flask 源代码后需要重启 Flask 程序 这两个问题非常的影响开发效率,因此 Flask ...
随机推荐
- 开机启动服务(ftp、apache、mysql)
当linux服务器开机时,会将 /etc/rc.d/rc.local 中的指令全部执行一遍, 因此将相应服务的启动指令放到该shell脚本中即可实现开机启动效果; 在 /etc/rc.d/rc.loc ...
- puma(5300✨) Rails的一个多线程,高并发处理的web server
https://github.com/puma/puma 在开发和产品环境下,Puma是一个简单,快速,多线程,并高并发highly concurrent HTTP1.1server for Ruby ...
- Tree各种遍历实现
数据结构.算法及应用 张宪超主编 科学出版社 1. 数据结构的基本概念知识 数据结构的逻辑结构由数据节点和连接两个节点的边组成. 数据节点的数据类型:整型,实数型,布尔型,字符型,指针数据类型 结构的 ...
- lseek使用说明
lseek使用说明 表头文件#include<sys/types.h>#include<unistd.h> 定义函数off_t lseek(int filde,off_t of ...
- Hadoop学习资料整理
1.hadoop相关 hadoop 0.18文档(详细介绍Hadoop,MapReduce,FS Shell,Streaming等) hadoop资料汇总 2.实习的时候用的是streaming,非j ...
- 利用Appium Python测试爱壁纸的登录和设置壁纸
设置壁纸: #coding:utf-8 #Import the common package import os import unittest from appium import webdrive ...
- Java基础学习-Collection体系结构和迭代测试
package Collection; import java.util.ArrayList; import java.util.Collection; import java.util.Iterat ...
- APUE学习笔记——6.10 时间与时间例程 time_t
Unix提供的最基本的时间服务室日历时间(纪元时间),也就是计算1970年1月1日0时0分0秒到当前的秒数.该秒数用time_t表示. typedef long time_t; /* 时 ...
- vue.js 源代码学习笔记 ----- 工具方法 debug
import config from '../config' import { noop } from 'shared/util' let warn = noop let tip = noop let ...
- ThinkPHP5.0完全开发手册.【CHM】下载
ThinkPHP5已经出来很长时间了,官网也没有提供CHM格式的手册下载只有PDF格式的,我根据官网的在线手册制作了一个离线版的ThinkPHP5.0完全开发手册.CHM格式的文档.