欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

分享2個方便調(diào)試Python代碼的實(shí)用工具

 更新時間:2022年05月24日 17:04:51   作者:sgzqc  
這篇文章主要介紹了分享方便調(diào)試Python代碼的2個實(shí)用工具,可以方便展示我們調(diào)試代碼的中間狀態(tài),提升大家的編碼效率,詳細(xì)的介紹需要的小伙伴可以參考一下下面文章內(nèi)容

1. 引言

今天來給小伙伴推薦兩款實(shí)用的便于調(diào)試Python代碼的工具,可以方便展示我們調(diào)試代碼的中間狀態(tài),提升大家的編碼效率。

2. 動機(jī)

在日常工作中,經(jīng)常寫Python的小伙伴經(jīng)常會遇到需要調(diào)試代碼bug的情形,有時候我們Python的錯誤提示信息特別丑,

舉例如下:

2 divided by 1 is equal to 2.0.
Traceback (most recent call last):
File "loguru_example.py", line 17, in <module>
divide_numbers(num_list)
File "loguru_example.py", line 11, in divide_numbers
res = division(num1, num2)
File "loguru_example.py", line 5, in division
return num1/num2
ZeroDivisionError: division by zero

如果你覺得尚可接受,那我們不妨來看下如下顯示錯誤的方式:

哇偶,沒有對比就沒有傷害,看了上述的顯示,有木有心動。
好滴,我們可以通過一些Python的第三方包,來實(shí)現(xiàn)上述調(diào)試效果。我們來看如下兩款第三方Python包:

  • Loguru: 更好的打印程序異常
  • snoop: 打印函數(shù)中正在執(zhí)行的代碼行

好了,接下來我們就來一個個的介紹這些好用的工具吧。

3. Loguru

Loguru是一個旨在使Python中的日志顯示變得有趣的庫。Loguru提供了許多有趣的功能,但我發(fā)現(xiàn)該庫最有用的一個功能是捕獲程序異常并顯示導(dǎo)致代碼失敗的變量值。

3.1 安裝

我們可以使用pip來直接進(jìn)行安裝,代碼如下:

pip install loguru

3.2 舉個栗子

為了理解Loguru是如何工作的,假設(shè)我們現(xiàn)在有兩個函數(shù)divisiondivide_numbers

如下所示:

from itertools import combinations
def division(num1: int, num2: int):
return num1/num2
def divide_numbers(num_list: list):
"""Division of 2 numbers in the number list """
for comb in combinations(num_list, 2):
num1, num2 = comb
res = division(num1, num2)
print(f"{num1} divided by {num2} is equal to {res}.")
if __name__ =='__main__':
num_list = [2, 1, 0]
divide_numbers(num_list)

注意??combinations([2,1,0], 2)??返回值為??[(2, 1), (2, 0), (1, 0)]??。

運(yùn)行上述代碼后,我們會出現(xiàn)以下錯誤:

2 divided by 1 is equal to 2.0.
Traceback (most recent call last):
File "loguru_example.py", line 17, in <module>
divide_numbers(num_list)
File "loguru_example.py", line 11, in divide_numbers
res = division(num1, num2)
File "loguru_example.py", line 5, in division
return num1/num2
ZeroDivisionError: division by zero

3.3 使用Loguru

通過上述輸出,我們知道代碼行 ??return num1/num2 ??是錯誤發(fā)生的地方,但是我們并不清楚??num1??和??num2??的那些值導(dǎo)致的錯誤。幸運(yùn)的是,我們可以通過添加Loguru的裝飾器來捕捉此時的異常,

代碼如下:

from loguru import logger
from itertools import combinations
def division(num1: int, num2: int):
return num1/num2
@logger.catch # Add this to track errors
def divide_numbers(num_list: list):
for comb in combinations(num_list, 2):
num1, num2 = comb
res = division(num1, num2)
print(f"{num1} divided by {num2} is equal to {res}.")
if __name__ =='__main__':
num_list = [2, 1, 0]
divide_numbers(num_list)

運(yùn)行結(jié)果如下:

通過在代碼中添加logger.catch,此時的異常情況更加容易被理解!我們通過觀察此時的輸出,可以明確的知道當(dāng)2除以0時導(dǎo)致函數(shù)出現(xiàn)異常錯誤信息。

4. Snoop

如果我們編寫完的代碼經(jīng)過調(diào)試后沒有了錯誤,但我們想弄清楚代碼運(yùn)行時發(fā)生了什么?這就是snoop派上用場的情形。

4.1 安裝

snoop是一個第三方的Python包,通過只添加一個裝飾器可以方便地打印正在執(zhí)行的代碼行以及每個變量的值。
同樣我們依然可以通過pip來安裝snoop庫,代碼如下:

pip install snoop

4.2 舉例

假設(shè)我們有一個名為factorial的函數(shù),它主要用于實(shí)現(xiàn)計(jì)算整數(shù)的階乘。

代碼如下:

import snoop
def factorial(x: int):
if x == 1:
return 1
else:
return (x * factorial(x-1))
if __name__ == "__main__":
num = 5
print(f"The factorial of {num} is {factorial(num)}")

輸出如下:

The factorial of 5 is 120

 

4.3 使用factorial

為了理解為什么函數(shù)factorial的輸出值為20,我們可以通過添加snoop的裝飾器來查看函數(shù)的調(diào)用情形,

代碼如下:

import snoop
@snoop
def factorial(x):
if x == 1:
return 1
else:
return (x * factorial(x-1))
if __name__ == "__main__":
num = 5
print(f"The factorial of {num} is {factorial(num)}")

輸出如下:

在上述輸出中,我們可以查看變量的值以及實(shí)際代碼運(yùn)行情形。進(jìn)而通過上述輸出,我們可以更好地理解遞歸的工作原理!

5. 總結(jié)

文章重點(diǎn)介紹了兩種跟蹤和可視化Python代碼執(zhí)行的工具。我希望通過使用這兩款調(diào)試工具,來大大提升大家的工作效率和定位問題的能力。

到此這篇關(guān)于分享方便調(diào)試Python代碼的2個實(shí)用工具的文章就介紹到這了,更多相關(guān) Python調(diào)試代碼工具內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Python 發(fā)送SMTP郵件的簡單教程

    Python 發(fā)送SMTP郵件的簡單教程

    SMTP(Simple Mail Transfer Protocol)簡單郵件傳輸協(xié)議,Python內(nèi)置對SMTP的支持,可以發(fā)送純文本文件,HTML郵件以及附帶文件。本文講解如何使用python發(fā)送郵件
    2021-06-06
  • python 實(shí)現(xiàn)讓字典的value 成為列表

    python 實(shí)現(xiàn)讓字典的value 成為列表

    今天小編就為大家分享一篇python 實(shí)現(xiàn)讓字典的value 成為列表,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-12-12
  • 用Python的pandas框架操作Excel文件中的數(shù)據(jù)教程

    用Python的pandas框架操作Excel文件中的數(shù)據(jù)教程

    這篇文章主要介紹了用Python的pandas框架操作Excel文件中的數(shù)據(jù)教程,包括單位格式轉(zhuǎn)換、分類匯總等基本操作,需要的朋友可以參考下
    2015-03-03
  • 使用 Python 清理收藏夾里已失效的網(wǎng)站

    使用 Python 清理收藏夾里已失效的網(wǎng)站

    這篇文章主要介紹了用 Python 清理收藏夾里已失效的網(wǎng)站,本文通過截圖實(shí)例代碼的形式給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-12-12
  • Python 如何求矩陣的逆

    Python 如何求矩陣的逆

    這篇文章主要介紹了Python 如何求矩陣的逆案例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-03-03
  • python直接訪問私有屬性的簡單方法

    python直接訪問私有屬性的簡單方法

    下面小編就為大家?guī)硪黄猵ython直接訪問私有屬性的簡單方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-07-07
  • python檢查URL是否正常訪問的小技巧

    python檢查URL是否正常訪問的小技巧

    檢查一個URL是否正常很容易,如果檢查2000個URL,或者是大批量的URL怎么辦?這篇文章就為大家介紹了python檢查URL是否正常訪問的小技巧,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-02-02
  • python+matplotlib演示電偶極子實(shí)例代碼

    python+matplotlib演示電偶極子實(shí)例代碼

    這篇文章主要介紹了python+matplotlib演示電偶極子實(shí)例代碼,具有一定借鑒價值,需要的朋友可以參考下
    2018-01-01
  • python類參數(shù)self使用示例

    python類參數(shù)self使用示例

    python中__new__和__init__到底是怎么一回事,使用方法看下面的代碼,大家參考使用吧
    2014-02-02
  • 在Django框架中設(shè)置語言偏好的教程

    在Django框架中設(shè)置語言偏好的教程

    這篇文章主要介紹了在Django框架中設(shè)置語言偏好的教程,Django是最具人氣的Python框架,需要的朋友可以參考下
    2015-07-07

最新評論