简单实用,Python代码调试利器
本文示例代碼及文件已上傳至我的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?icfor?i?in?range(3):j?=?i?+?1k?=?i?**?2print('i?:?',?i,?'j?:?',?j,?'k?:?',?k)而基于icecream,事情就變得簡單了一些:
for?i?in?range(3):j?=?i?+?1k?=?i?**?2ic(i,?j,?k)比較一下差異,效果一目了然:
這就是icecream的基礎用法,下面我們來學習其更加豐富的功能特性:
2.1 利用icecream檢查各種變量
icecream可以對任何類型的變量進行檢查,只需將變量傳入ic()中即可,甚至連pandas中的數據框都可以友好地進行打印輸出:
import?pandas?as?pddef?demo_func(x):return?x?+?1class?DemoClass:a?=?1demo_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?icdef?demo():ic()a?=?1if?1?>?0:ic()a?+=?1else:ic()a?-=?1demo()2.3 一處導入處處使用
當你的項目擁有一個主文件,其他的子模塊都在主文件中被調用時,那么你就可以在主文件開頭執行下列代碼,之后無需在子模塊中導入icecream也可以使用ic():
from?icecream?import?install install()2.4 個性化設置
除了使用icecream默認的信息打印格式之外,我們還可以利用ic.configureOutput()來自定義一些顯示參數,譬如:
更多自定義參數可以訪問https://github.com/gruns/icecream#configuration查看更多。
正如icecream的簡介中所說的那樣:別再使用print()進行debug,大家可以在日常使用過程中多多使用icecream,體會其便捷之處。
以上就是本文的全部內容,歡迎在評論區與我進行討論~
各位伙伴們好,詹帥本帥搭建了一個個人博客和小程序,匯集各種干貨和資源,也方便大家閱讀,感興趣的小伙伴請移步小程序體驗一下哦!(歡迎提建議)
推薦閱讀
牛逼!Python常用數據類型的基本操作(長文系列第①篇)
牛逼!Python的判斷、循環和各種表達式(長文系列第②篇)
牛逼!Python函數和文件操作(長文系列第③篇)
牛逼!Python錯誤、異常和模塊(長文系列第④篇)
總結
以上是生活随笔為你收集整理的简单实用,Python代码调试利器的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 还在对Matplotlib繁琐的图层设置
- 下一篇: 使用pg_resetwal时空穿梭找回“