簡單實用,Python 代碼調試利器
添加微信號 "CNFeffery" 加入技術交流羣
本文示例代碼及文件已上傳至我的
Github
倉庫 https://github.com/CNFeffery/DataScienceStudyNotes
1 簡介
儘管有那麼多花裏胡哨的debug
工具和方式供我們選擇,但不得不承認,在大多數情況下,print() 纔是最方便的代碼調試方式😂,通過手動在程序中的關鍵位置書寫合適的打印語句,可以很快速地幫助我們瞭解到程序運行的過程,發現問題所在。
而icecream
就是一個將 print 大法發揮到極致的Python
庫,它的工作方式有些像vscode
中針對javascript
的插件Turbo Console Log
,下面就讓我們一起來領略icecream
中的實用功能吧🍦~
2 利用 icecream 進行高效 debug
讓我們先來看看icecream
最基礎的使用方式,假如我們需要在循環過程中打印每一輪對應的幾個變量,爲了使得顯示的信息更爲清楚,傳統的方式可以這樣做:
from icecream import ic
for i in range(3):
j = i + 1
k = i ** 2
print('i : ', i, 'j : ', j, 'k : ', k)
而基於icecream
,事情就變得簡單了一些:
for i in range(3):
j = i + 1
k = i ** 2
ic(i, j, k)
比較一下差異,效果一目瞭然:
這就是icecream
的基礎用法,下面我們來學習其更加豐富的功能特性:
2.1 利用 icecream 檢查各種變量
icecream
可以對任何類型的變量進行檢查,只需將變量傳入ic()
中即可,甚至連pandas
中的數據框都可以友好地進行打印輸出:
import pandas as pd
def demo_func(x):
return x + 1
class DemoClass:
a = 1
demo_df = pd.DataFrame({
'a': [1, 2, 3],
'b': ['a', 'b', 'c']
})
ic(demo_func(1))
ic(DemoClass.a)
ic(demo_df);
2.2 檢查代碼執行位置
很多時候我們在調試代碼打印一些關鍵位置結果時,希望可以快速找到對應結果在代碼中的位置,利用ic()
,不傳遞任何參數時,會自動打印出所在位置、所屬父級函數等信息:
from icecream import ic
def demo():
ic()
a = 1
if 1 > 0:
ic()
a += 1
else:
ic()
a -= 1
demo()
2.3 一處導入處處使用
當你的項目擁有一個主文件,其他的子模塊都在主文件中被調用時,那麼你就可以在主文件開頭執行下列代碼,之後無需在子模塊中導入icecream
也可以使用ic()
:
from icecream import install
install()
2.4 個性化設置
除了使用icecream
默認的信息打印格式之外,我們還可以利用ic.configureOutput()
來自定義一些顯示參數,譬如:
更多自定義參數可以訪問https://github.com/gruns/icecream#configuration
查看更多。
正如icecream
的簡介中所說的那樣:別再使用 print() 進行 debug,大家可以在日常使用過程中多多使用icecream
,體會其便捷之處。
以上就是本文的全部內容,歡迎在評論區與我進行討論~
本文由 Readfog 進行 AMP 轉碼,版權歸原作者所有。
來源:https://mp.weixin.qq.com/s/e_R5Ejyz-w_yjH3ZiRM-pw