濮阳杆衣贸易有限公司

主頁 > 知識(shí)庫 > GitHub 熱門:別再用 print 輸出來調(diào)試代碼了

GitHub 熱門:別再用 print 輸出來調(diào)試代碼了

熱門標(biāo)簽:無錫電銷機(jī)器人銷售 招聘信息 去哪里辦卡 地圖標(biāo)注審核工作怎么樣注冊(cè) 地圖標(biāo)注植物名稱 南召400電話辦理資費(fèi) 揭陽外呼系統(tǒng)公司 鄭州中國(guó)移動(dòng)400電話申請(qǐng) 熱血傳奇沃瑪森林地圖標(biāo)注 福建ai電銷機(jī)器人加盟公司

4 月 23 日,GitHub 每日趨勢(shì)榜第一位是一個(gè) Python ,相關(guān)項(xiàng)目:PySnooper。

該項(xiàng)目很快獲取 2200 Star。

PySnooper 是個(gè)什么東西?

如果你寫的 Python 代碼不能按如期那樣運(yùn)行,你會(huì)絞盡腦汁想為啥出錯(cuò)了。雖然你希望有支持?jǐn)帱c(diǎn)的成熟調(diào)試器,但或許你現(xiàn)在不想去設(shè)置這樣的調(diào)試器。

你想知道哪些行代碼是正常運(yùn)行,哪些行不正常。據(jù)說大多數(shù)人會(huì)在可疑位置使用 print 輸出語句。

其實(shí) PySnooper 的作用有點(diǎn)類似,你不用小心謹(jǐn)慎地用 print 輸出語句,只需在想調(diào)試的函數(shù)中引入一個(gè)裝飾器。然后得到函數(shù)的詳細(xì)日志,包括運(yùn)行了哪些行、何時(shí)運(yùn)行,以及何時(shí)更改了局部變量。

為什么 PySnooper 能從其他智能調(diào)試工具中脫穎而出?

因?yàn)槟憧梢栽诓恍枰M(jìn)行任何設(shè)置的情況下將其用于糟糕的、龐大的企業(yè)代碼庫中。只需打開裝飾器(如下示例所示),并將輸出重定向到一個(gè)專用的日志文件,將日志文件路徑指定為第一個(gè)參數(shù)。

使用范例

范例是一個(gè)把數(shù)字轉(zhuǎn)成二進(jìn)制的函數(shù)。

import pysnooper
@pysnooper.snoop()
def number_to_bits(number):
  if number:
    bits = []
    while number:
      number, remainder = divmod(number, 2)
      bits.insert(0, remainder)
    return bits
  else:
    return [0]
number_to_bits(6)

輸出范例

Starting var:.. number = 6
21:14:32.099769 call     3 @pysnooper.snoop()
21:14:32.099769 line     5   if number:
21:14:32.099769 line     6     bits = []
New var:....... bits = []
21:14:32.099769 line     7     while number:
21:14:32.099769 line     8       number, remainder = divmod(number, 2)
New var:....... remainder = 0
Modified var:.. number = 3
21:14:32.099769 line     9       bits.insert(0, remainder)
Modified var:.. bits = [0]
21:14:32.099769 line     7     while number:
21:14:32.099769 line     8       number, remainder = divmod(number, 2)
Modified var:.. number = 1
Modified var:.. remainder = 1
21:14:32.099769 line     9       bits.insert(0, remainder)
Modified var:.. bits = [1, 0]
21:14:32.099769 line     7     while number:
21:14:32.099769 line     8       number, remainder = divmod(number, 2)
Modified var:.. number = 0
21:14:32.099769 line     9       bits.insert(0, remainder)
Modified var:.. bits = [1, 1, 0]
21:14:32.099769 line     7     while number:
21:14:32.099769 line    10     return bits
21:14:32.099769 return   10     return bits

有興趣的童鞋,請(qǐng)收藏:

https://github.com/cool-RR/PySnooper

好了,本文就給大家介紹到這里,希望對(duì)大家有所幫助!

您可能感興趣的文章:
  • python調(diào)試神器PySnooper的使用
  • 詳解DeBug Python神級(jí)工具PySnooper
  • PHP 中 var_export、print_r、var_dump 調(diào)試中的區(qū)別
  • php 調(diào)試?yán)鱠ebug_print_backtrace()
  • 關(guān)于PySnooper 永遠(yuǎn)不要使用print進(jìn)行調(diào)試的問題

標(biāo)簽:黔南 桂林 景德鎮(zhèn) 鹽城 文山 東莞 南昌 宣城

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《GitHub 熱門:別再用 print 輸出來調(diào)試代碼了》,本文關(guān)鍵詞  GitHub,熱門,別,再用,print,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《GitHub 熱門:別再用 print 輸出來調(diào)試代碼了》相關(guān)的同類信息!
  • 本頁收集關(guān)于GitHub 熱門:別再用 print 輸出來調(diào)試代碼了的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    洛阳市| 浮梁县| 遂溪县| 城市| 奉贤区| 牙克石市| 沾化县| 云和县| 丰台区| 绵竹市| 合肥市| 澳门| 东乌珠穆沁旗| 临澧县| 遂昌县| 阳江市| 阜新市| 云阳县| 台北市| 慈溪市| 盐亭县| 玉溪市| 墨玉县| 威信县| 桐梓县| 蕲春县| 宣恩县| 逊克县| 集安市| 依安县| 衢州市| 杂多县| 合山市| 蒙山县| 六安市| 浦东新区| 克拉玛依市| 西昌市| 乌苏市| 丹东市| 休宁县|