自學(xué)Python教程【第六十節(jié)】調(diào)試程序
雖然我們大多數(shù)都是第一次接觸Python編程,甚至是第一次接觸編程,但是我們或多或少已經(jīng)面對過一些代碼異常的狀況了,你是怎么處理的呢?你的處理方法適合應(yīng)對大體積的較復(fù)雜的異常嗎?
寫代碼,不可避免地會出現(xiàn)bug。很多人在初學(xué)編程的時候,當寫完程序運行時,發(fā)現(xiàn)結(jié)果與自己預(yù)料中的不同,或者程序意外中止了,就一時沒了想法,不知道該從何下手,只能反復(fù)重新運行程序,期待忽然有次結(jié)果就對了。
今天我就來講講代碼遇到問題時的一些簡單處理方法。
1. 讀錯誤信息
來看如下一個例程:
import random a = 0 for i in range(5): b = random.choice(range(5)) a += i / b print a
這個程序中,i從0循環(huán)到4,每次循環(huán)中,b是0到4中的一個隨機數(shù)。把i/b的結(jié)果累加到a上,最后輸出結(jié)果。
運行這段程序,有時候會輸出結(jié)果,有時候卻跳出錯誤信息:
Traceback (most recent call last): File "C:\Users\Crossin\Desktop\py\test.py", line 6, in <module> a += i / b ZeroDivisionError: integer division or modulo by zero
有些同學(xué)看見一段英文提示就慌了。其實沒那么復(fù)雜,Python的錯誤提示做得還是很標準的。
它告訴我們錯誤發(fā)生在test.py文件中的第6行
a += i / b
這一句上。
這個錯誤是“ZeroDivisionError”,也就是除零錯。
“integer division or modulo by zero”,整數(shù)被0除或者被0模(取余數(shù))。
因為0不能作為除數(shù),所以當b隨機到0的時候,就會引發(fā)這個錯誤。
知道了原因,就可以順利地解決掉這個bug。
以后在寫代碼的時候,如果遇到了錯誤,先別急著去改代碼。試著去讀一讀錯誤提示,看看里面都說了些啥。
2. 輸出調(diào)試信息
我們在所有課程的最開始就教了輸出函數(shù)“print”。它是編程中最簡單的調(diào)試手段。有的時候,僅從錯誤提示仍然無法判斷出程序錯誤的原因,或者沒有發(fā)生錯誤,但程序的結(jié)果就是不對。這種情況下,通過輸出程序過程中的一些狀態(tài),可以幫助分析程序。
把前面那個程序改造一下,加入一些與程序功能無關(guān)的輸出語句:
import random a = 0 for i in range(5): print 'i: %d' % i b = random.choice(range(5)) print 'b: %d' % b a += i / b print 'a: %d' % a print print a
運行后的輸出結(jié)果(每次結(jié)果都會不一樣):
i: 0 b: 3 a: 0 i: 1 b: 3 a: 0 i: 2 b: 3 a: 0 i: 3 b: 0 Traceback (most recent call last): File "C:\Users\Crossin\Desktop\py\test.py", line 8, in <module> a += i / b ZeroDivisionError: integer division or modulo by zero
當b的值為0時,發(fā)生了除零錯。這次可以更清晰地看出程序出錯時的狀態(tài)。
在真實開發(fā)中,程序的結(jié)構(gòu)可能會非常復(fù)雜。通過輸出調(diào)試信息,可以有效地縮小范圍、定位錯誤發(fā)生的位置,確認錯誤發(fā)生時的場景,進而找出錯誤原因。
恭喜您在Python自學(xué)的道路上又堅持了一天,這節(jié)課我們學(xué)習(xí)的調(diào)試程序的相關(guān)內(nèi)容,你學(xué)會了嗎?其實這節(jié)課的相關(guān)內(nèi)容,在我們學(xué)習(xí)編程、實戰(zhàn)的過程中還是蠻重要的,但我們這節(jié)課的內(nèi)容有限,相關(guān)知識大家還需要課下去搜集學(xué)習(xí),加油!
好啦,今天的分享到這里就結(jié)束了,希望大家持續(xù)關(guān)注馬哥教育官網(wǎng),每天都會有大量優(yōu)質(zhì)內(nèi)容與大家分享!
聲明:文章來源于網(wǎng)絡(luò),侵刪!