flask開啟debug調(diào)試模式的方法?這個(gè)問題可能是我們?nèi)粘W(xué)習(xí)或工作經(jīng)常見到的。希望通過這個(gè)問題能讓你收獲頗深。下面是小編給大家?guī)淼膮⒖純?nèi)容,讓我們一起來看看吧!
創(chuàng)新互聯(lián)建站-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價(jià)比大名網(wǎng)站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫,直接使用。一站式大名網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋大名地區(qū)。費(fèi)用合理售后完善,十多年實(shí)體公司更值得信賴。
flask默認(rèn)是沒有開啟debug模式的,開啟debug模式有很多好處:
第一,可以幫助我們查找代碼里面的錯(cuò)誤,比如:
from flask import 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()
我們都知道,除數(shù)是不能為0的,但是上面的代碼里y的值是0,我們運(yùn)行這段代碼,然后去地址查看,只能看到內(nèi)部服務(wù)錯(cuò)誤,但是沒有任何錯(cuò)誤原因的說明,我們找起原因就會非常費(fèi)勁。
除了方便找到bug以外,還有另一個(gè)原因促使我們開啟debug模式,就是如果我們不開啟debug模式,我們修改了上面代碼里y的值不等于0,然后ctrl+s保存代碼,去頁面刷新頁面仍然是上圖,也就是說Ctrl+s沒有重新加載代碼的運(yùn)行,如果我們每次修改代碼都要重新運(yùn)行代碼才能看到結(jié)果,是不是非常的不方便呢?以上兩個(gè)原因,讓我們需要開啟debug模式:
開啟debug模式只需要我們加一句app.debug = True即可。重新運(yùn)行代碼以后我們發(fā)現(xiàn)控制臺輸出的內(nèi)容也和之前不一樣了,系統(tǒng)會提示你重啟了服務(wù)并且開啟了debug模式。(更多學(xué)習(xí)教程,請點(diǎn)擊創(chuàng)新互聯(lián)。)
現(xiàn)在去刷新頁面,會發(fā)現(xiàn)頁面提示了我們報(bào)錯(cuò)的原因:
而且在報(bào)錯(cuò)的最下面可以看到代碼報(bào)錯(cuò)的位置和原因:
現(xiàn)在我們來說一下控制臺輸出的最后一行的PIN碼:
我們先來到報(bào)錯(cuò)頁面代碼報(bào)錯(cuò)的位置,將鼠標(biāo)放在報(bào)錯(cuò)語句上會看到后面有一個(gè)命令行樣子的圖標(biāo):
現(xiàn)在點(diǎn)擊那個(gè)圖標(biāo):
會發(fā)現(xiàn)頁面彈出了這么一個(gè)框:
上面說著(翻譯):控制臺被鎖定,需要輸入PIN來解鎖。PIN已經(jīng)在你運(yùn)行服務(wù)(就是你的代碼)的shell(就是工具,我們用的是pychram)標(biāo)準(zhǔn)輸出里打印出來了,你可以在那里找到它。
我們把PIN碼粘貼過去就能看到:
我們可以直接在這里調(diào)試了,我們需要看一下y的值是不是真的是0,我們print y一下:
這樣就快速的定位到了問題的所在了。而且這個(gè)PIN值是不需要你每次都輸入的,你只要輸入一次,8小時(shí)以內(nèi)都不需要再次輸入的,因?yàn)閒lask會生成一個(gè)cookie信息,記錄你的登錄狀態(tài)。
當(dāng)然開啟debug模式并不是只有上面一種方式:
app.run(debug=True)
# coding: utf-8 from flask import Flask # __name__是用來確定flask運(yùn)行的主文件 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運(yùn)行的主文件 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()
第四種開啟方式——加載文件
我們新建一個(gè)名為configs的py文件,內(nèi)面寫:
# coding: utf-8 DEBUG = True
然后在代碼里先導(dǎo)入import configs再引用這個(gè)文件
app.config.from_object(configs)Ctrl+s保存就會看到設(shè)置生效了:
代碼如下:
# coding: utf-8 from flask import Flask import configs # __name__是用來確定flask運(yùn)行的主文件 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()
此外,如果你不導(dǎo)入import configsconfigs文件想用配置,那你也可以將上面代碼里的app.config.from_object(configs)修改為
app.config.from_object('configs')就是加個(gè)引號,這樣也是可以的。
感謝各位的閱讀!看完上述內(nèi)容,你們對flask開啟debug調(diào)試模式的方法大概了解了嗎?希望文章內(nèi)容對大家有所幫助。如果想了解更多相關(guān)文章內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。