python的調試;print()和斷言(實例解析二)

乌拉乌拉~
發布: 2018-08-23 13:38:04
原創
1732 人瀏覽過

在以下的文章之中我們來了解python中的調試。了解一些什麼python調試的方法,以及知曉python調試在python編程之中能起到什麼樣的作用。

為什麼要進行偵錯

程式能一次寫完並正常運作的機率很小,基本上不超過1%。總是會有各種各樣的bug需要修正。有的bug很簡單,看看錯誤訊息就知道,有的bug很複雜,我們需要知道出錯時,哪些變數的值是正確的,哪些變數的值是錯誤的,因此,需要一整套調試程式的手段來修復bug。那麼python怎麼調試呢?下面將會給予與解答。

第一種方法簡單直接粗暴有效,就是用print()把可能有問題的變數印出來看看:

def foo(s):
    n = int(s)
    print('>>> n = %d' % n)
    return 10 / n
def main():
    foo('0')
main()
登入後複製

執行後在輸出中找印出的變數值:

$ python err.py
>>> n = 0
Traceback (most recent call last):
  ...
ZeroDivisionError: integer division or modulo by zero
登入後複製

用print()最大的壞處是將來還要刪掉它,想想程式裡到處都是print(),運行結果也會包含很多垃圾訊息。所以,我們又有第二種方法。

第二種方法就是:凡是用print()來輔助查看的地方,都可以用斷言(assert)來取代:

def foo(s):
    n = int(s)   
     assert n != 0, 'n is zero!'
    return 10 / n
    
    def main():
    foo('0')
登入後複製

assert的意思是,表達式n != 0應該是True,否則,根據程式運行的邏輯,後面的程式碼一定會出錯。

如果斷言失敗,assert語句本身就會拋出AssertionError:

$ python err.py
Traceback (most recent call last):
  ...
AssertionError: n is zero!
登入後複製

程式中如果到處充斥著assert,和print()相比也好不到哪裡去。不過,啟動Python解釋器時可以用-O參數來關閉assert:

$ python -O err.py
Traceback (most recent call last):
  ...
ZeroDivisionError: division by zero
登入後複製

關閉後,你可以把所有的assert語句當成pass來看。

以上就是本篇文章所講述的所有內容,這篇文章主要介紹了python調試的相關知識,希望你能藉助資料從而理解上述所說的內容。希望我在這片文章所講述的內容能夠對你有幫助,讓你學習python更加輕鬆。

更多相關知識,請造訪php中文網Python教學欄位。

以上是python的調試;print()和斷言(實例解析二)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板