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模式的更多相关文章

  1. Flask最强攻略 - 跟DragonFire学Flask - 第五篇 做一个用户登录之后查看学员信息的小例子

    需求: 1. 用户名: oldboy 密码: oldboy123 2. 用户登录成功之后跳转到列表页面 3. 失败有消息提示,重新登录 4.点击学生名称之后,可以看到学生的详细信息 后端: from ...

  2. flask 第五篇

    需求: 1. 用户名: oldboy 密码: oldboy123 2. 用户登录成功之后跳转到列表页面 3. 失败有消息提示,重新登录 4.点击学生名称之后,可以看到学生的详细信息 后端: from ...

  3. Nexus6P 设置Debug模式

    一劳永逸,设置手机进入Debug模式实现完美Root 使用mkbootimg进行boot.ing编辑 将修改的系统官方Rom包中的boot.ing和mkbooting工具中的mkboot.mkboot ...

  4. Linux下Tomcat启动设置debug模式启动

    原文: https://blog.csdn.net/li295214001/article/details/42077247 https://blog.csdn.net/jackie_xiaonan/ ...

  5. tomcat设置debug模式

    1.设置 编辑catalina.bat,在 rem Guess CATALINA_HOME if not definedset "CURRENT_DIR=%cd%"if not & ...

  6. 在.net中设置debug模式预设代码

    #region DEBUG #if DEBUG this.WorkOrgID.Value = "4DC4507E-434D-4EEB-967E-1E5CC28AA0C1"; thi ...

  7. springboot第四篇:debug模式开发运用

    前提:项目是以maven project结构建立的,现状是无法进行断点调试的.怎么才能在eclipse里进行调试呢? 需要:①将项目打包部署到tomcat ②往项目加入dynamic web modu ...

  8. flask学习(四):debug模式

    一. 设置debug模式 1. flask 1.0之前 在app.run()中传入一个关键字参数debug,app.run(debug=True),就设置当前项目为debug模式 2. flask 1 ...

  9. Flask(6)- debug 模式

    使用 Flask 开发过程中存在两个常见的问题 当 Flask 程序出错时,没有提示错误的详细信息 修改 Flask 源代码后需要重启 Flask 程序 这两个问题非常的影响开发效率,因此 Flask ...

随机推荐

  1. Runtime.getRuntime.exec();

    杀死Chrome浏览器进程 private static void closeAllChrome() throws IOException{ Runtime.getRuntime().exec(&qu ...

  2. linux bash shell中,单引号、 双引号,反引号(``)的区别及各种括号的区别

    一.单引号和双引号 首先,单引号和双引号,都是为了解决中间有空格的问题. 因为空格在Linux中时作为一个很典型的分隔符,比如string1=this is astring,这样执行就会报错.为了避免 ...

  3. FastDFS图片服务器

    首先要转一个FastDFS,这个很难装.一般由运维人员安装. git项目fastdfs-client-java由happy fish开发的,down下来后import到项目中maven install ...

  4. [洛谷U63006]导函数最小系数

    U63006 导函数最小系数 题面 给出一个n次函数\(f(x)=a_{n}x^{n}+a_{n-1}x^{n-1}+...+a_{1}x+a_0\)的各项系数\(a_n,a_{n-1}...a_1, ...

  5. Linux命令详解-date

    在linux环境中,不管是编程还是其他维护,时间是必不可少的,也经常会用到时间的运算,熟练运用date命令来表示自己想要表示的时间,肯定可以给自己的工作带来诸多方便. 1.命令格式:   date [ ...

  6. UVALive-5713 Qin Shi Huang's National Road System (次小生成树)

    题目大意:有n个城市,要修一些路使得任意两个城市都能连通.但是有人答应可以不计成本的帮你修一条路,为了使成本最低,你要慎重选择修哪一条路.假设其余的道路长度为B,那条别人帮忙修的道路两端城市中的总人口 ...

  7. UVALive-3713 Astronauts (2-SAT)

    题目大意:有三个任务A.B.C,n个已知年龄的人.A任务只能被年龄不小于平均年龄的人做,B任务只能被平均年龄以下的人做,C任务不限,相互讨厌的两个人不能做同一件任务,现在已知厌恶关系,求一种任务分配方 ...

  8. EASYUI 1.4版 combobox firefox 下不支持中文检索的问题

    easyui 的combobox 在IE下面输入中文,可以自动实现筛选和检索的功能,但是在firefox下面不可以. 于是查了一些资料,发现原来是浏览器对于中文输入法的处理问题,对于chrome 和 ...

  9. Symmetrical Network Acceleration with EBS 12

    Andy Tremayne, my esteemed colleague and fellow blogger, has published a new whitepaper that discuss ...

  10. element UI 中DateTimePicker 回传时间选择

    之前在项目中用vue和element,日期和时间选择用的element2.0 的DateTimePicker 日期选择后提交没问题,在编辑页面通过后端返回时间字符串(敲黑板,这里是重点)绑定也没洒问题 ...