欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

Python常見(jiàn)的三個(gè)調(diào)試工具-創(chuàng)新互聯(lián)

創(chuàng)新互聯(lián)www.cdcxhl.cn八線動(dòng)態(tài)BGP香港云服務(wù)器提供商,新人活動(dòng)買(mǎi)多久送多久,劃算不套路!

成都創(chuàng)新互聯(lián)主營(yíng)牙克石網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司,主營(yíng)網(wǎng)站建設(shè)方案,重慶APP開(kāi)發(fā),牙克石h5微信小程序定制開(kāi)發(fā)搭建,牙克石網(wǎng)站營(yíng)銷(xiāo)推廣歡迎牙克石等地區(qū)企業(yè)咨詢

今天就跟大家聊聊有關(guān)Python常見(jiàn)的三個(gè)調(diào)試工具,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。

對(duì)于 python 代碼的調(diào)試我們通常都是使用 IDE 自帶的調(diào)試功能。但是 IDE 提供的調(diào)試功能存在局限性,例如在測(cè)試服務(wù)器上調(diào)試代碼,但是又不可能在測(cè)試服務(wù)器上安裝 IDE 進(jìn)行調(diào)試。這時(shí)我們就可以利用下面所講解的三個(gè)工具進(jìn)行調(diào)試。

準(zhǔn)備調(diào)試代碼

在講解三個(gè)調(diào)試工具前,我們先編寫(xiě)待調(diào)試的代碼。代碼很簡(jiǎn)單,就是計(jì)算兩個(gè)數(shù)的商。我們?cè)诰帉?xiě)代碼的時(shí)候故意留下了除數(shù)為 0 的 bug。

def division(start, end):
    for i in range(start, end, -1):
        num1 = i
        num2 = i - 1
        result = num1 / num2
        print(result)

if __name__ == '__main__':
    division(10, 0)

PySnooper

PySnooper 是 Python 的第三方工具庫(kù),它可以精確的顯示代碼的執(zhí)行時(shí)間、執(zhí)行順序和代碼中的局部變量值的變化等。PySnooper 使用方法很簡(jiǎn)單,只需要將它作為裝飾器來(lái)使用即可。下面我們來(lái)看一下具體使用步驟:

1. 安裝 PySnooper

在控制臺(tái)輸入如下命令:

pip install pysnooper

2. 加入 PySnooper

首先需要引入 PySnooper

import pysnooper

接著在需要測(cè)試的函數(shù)上加上 pysnooper 裝飾器

@pysnooper.snoop()
def division(start, end):
    for i in range(start, end, -1):
        num1 = i
        num2 = i - 1
        result = num1 / num2
        print(result)
 
if __name__ == '__main__':
    division(10, 0)

在控制臺(tái)輸入命令:

python text.py

運(yùn)行代碼后,控制臺(tái)輸出如下內(nèi)容:

Python常見(jiàn)的三個(gè)調(diào)試工具

Python常見(jiàn)的三個(gè)調(diào)試工具

上圖只截取了 PySnooper 輸出日志的開(kāi)頭內(nèi)容和最后結(jié)尾的內(nèi)容。從截圖中我們可以看到 PySnooper 輸出了每行代碼的運(yùn)行順序、運(yùn)行時(shí)間和代碼運(yùn)行中變量值的變化,以及報(bào)錯(cuò)信息。在實(shí)際項(xiàng)目中 PySnooper 輸出的日志內(nèi)容會(huì)很多,在控制臺(tái)查看會(huì)很不方便,這時(shí)我們可以將日志輸出到本地文件中,我們只需在 PySnooper 裝飾器中加入日志保存路徑即可:

@pysnooper.snoop('/app/project_log.log')

@pysnooper.snoop(prefix='MyCompanyName: ')

前面我們所講的都是在函數(shù)上利用裝飾器來(lái)監(jiān)控整個(gè)函數(shù),但是在實(shí)際項(xiàng)目中往往一個(gè)函數(shù)內(nèi)容會(huì)很多,如果監(jiān)控整個(gè)函數(shù)會(huì)導(dǎo)致輸出的日志過(guò)多,這時(shí)我們就可以利用 PySnooper 的局部監(jiān)控功能來(lái)監(jiān)控函數(shù)中需要監(jiān)控的代碼片段?,F(xiàn)在我們來(lái)修改一下代碼,只監(jiān)控輸出的值:

import pysnooper
 
def division(start, end):
    for i in range(start, end, -1):
        with pysnooper.snoop():
            num1 = i
            num2 = i - 1
            result = num1 / num2
        print(result)
 
if __name__ == '__main__':
    division(10, 0)

Better-exceptions

Better-exceptions 同樣是 Python 的第三方工具庫(kù),它出現(xiàn)的原因是其實(shí)很簡(jiǎn)單就是“美化異常信息”(是不是感覺(jué)作者很任性)。Better-exceptions 主要使用了 Python 的 sys 模塊的 excepthook 方法,這個(gè)方法在當(dāng)系統(tǒng)拋出異常時(shí),解釋器就會(huì)調(diào)用它,同時(shí)傳遞三個(gè)參數(shù):異常類(lèi)、異常實(shí)例和 traceback 對(duì)象,這就說(shuō)明我們可以重寫(xiě)這個(gè)方法來(lái)捕獲系統(tǒng)異常。但是,因?yàn)槲覀兛梢灾貙?xiě) excepthook 方法來(lái)捕獲系統(tǒng)異常,因此 Better-exceptions 對(duì)與 Web 框架來(lái)說(shuō)是不起任何作用的,因?yàn)?Web 框架都已經(jīng)處理了系統(tǒng)拋出的異常,不會(huì)再以 hook 的方式觸發(fā) Better-exceptions 。下面我們就來(lái)看一下該怎么用。

1、安裝 Better-exceptions

首先在控制臺(tái)輸入如下命令:

pip install better-exceptions

接著我們?cè)诳刂婆_(tái)輸入如下代碼,來(lái)設(shè)置環(huán)境變量:

setx BETTER_EXCEPTIONS 1

2. 調(diào)試代碼

在控制臺(tái)輸入命令:

python text.py

代碼運(yùn)行后,控制臺(tái)輸出如下圖:

Python常見(jiàn)的三個(gè)調(diào)試工具

從上面的圖我們可以看到,Better-exceptions 對(duì)異常代碼進(jìn)行了著色,并對(duì)產(chǎn)生異常的變量值進(jìn)行了輸出。通過(guò)這兩項(xiàng)內(nèi)容我們就可以很快捷的看到具體報(bào)錯(cuò)位置和報(bào)錯(cuò)原因。這里有需要注意的地方就是,在 Windows 系統(tǒng)下輸出的日志會(huì)存在亂碼問(wèn)題,這是因?yàn)?Better-exceptions 的編碼格式造成的。要解決這個(gè)問(wèn)題我們只需要修改 better-exceptions 目錄下的 encoding.py 文件,講文件中的 ENCODING = locale.getpreferredencoding() 修改為 ENCODING = 'utf-8'即可。

PDB

PDB 是 Python 內(nèi)置的模塊,我們可以利用 PDB 設(shè)置斷點(diǎn)和跟蹤調(diào)試。PDB 的使用不需要再安裝第三方插件,只需要在命令行輸入如下命令:

python -m pdb Test.py

命令執(zhí)行后將會(huì)進(jìn)入 PDB 調(diào)試模式。如果需要在代碼中加入斷點(diǎn),只需要在需要加入斷點(diǎn)的位置。

Python常見(jiàn)的三個(gè)調(diào)試工具

總結(jié)

我們講解了 PySnooper 、Better-exceptions 和 PDB 的用法,這三種方法一般都使用在服務(wù)器上,這里我推薦使用Better-exceptions,因?yàn)樗鼘?duì)代碼的侵入性很小,幾乎不需要改變代碼。

看完上述內(nèi)容,你們對(duì)Python常見(jiàn)的三個(gè)調(diào)試工具有進(jìn)一步的了解嗎?如果還想了解更多知識(shí)或者相關(guān)內(nèi)容,請(qǐng)關(guān)注創(chuàng)新互聯(lián)-成都網(wǎng)站建設(shè)公司行業(yè)資訊頻道,感謝大家的支持。

分享標(biāo)題:Python常見(jiàn)的三個(gè)調(diào)試工具-創(chuàng)新互聯(lián)
當(dāng)前URL:http://aaarwkj.com/article48/hophp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站排名、定制開(kāi)發(fā)手機(jī)網(wǎng)站建設(shè)、移動(dòng)網(wǎng)站建設(shè)、品牌網(wǎng)站制作做網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都app開(kāi)發(fā)公司
亚洲一区日本一区二区| 久草尤物视频在线观看| 国产精品国产三级丝袜| 亚洲一区二区三区四区五区六| 清纯唯美校园春色亚洲激情| 国产91九色视频在线| 日进去了啊内射视频| 日本一区二区三区高清| 欧美日韩国产免费电影| 91九色国产在线视频| 国产三级视频在线观看视频 | 欧美成人高清在线播放| 九九热精品在线观看视频| 日韩天堂视频在线播放| 蜜臀午夜精品视频在线观看| 午夜国产精品福利一二| 日韩国产欧美亚洲一区不卡| 久久国产精品亚洲看片| 好吊视频在线免费观看| 日本欧美一区中文字幕| 羞羞的视频免费观看在线| 欧美中日韩一区二区三区| 国产精品国产亚洲精品| 国产传媒在线免费播放视频| 精品国产91高清在线观看| 精品久久久久久久久极品| 亚洲精品成人综合色在线| 护士一级特黄特色大片| 女性裸体无遮挡啪啪网站| 一级丰满少妇av大片| 亚洲黄色暴力一区视频| 久久伊人这里都是精品| av 一区二区三区av| 人人妻夜夜天天俺去添噜| av资源天堂第一区第二区第三区| 国内极品尤物视频在线| 粉嫩国产av一区二区三区| 亚洲一区二区三区 码| 国产一区二区主播不卡| 国产精品久久99粉嫩| 欧美日本一区二区四区|