Szukaj…


Debuger w języku Python: debugowanie krokowe za pomocą _pdb_

Biblioteka standardowa Python zawiera interaktywną bibliotekę debugowania o nazwie pdb . pdb ma szerokie możliwości, najczęściej wykorzystywaną jest możliwość „przejścia” programu.

Aby natychmiast rozpocząć debugowanie krokowe, użyj:

python -m pdb <my_file.py>

Spowoduje to uruchomienie debugera w pierwszej linii programu.

Zwykle będziesz chciał kierować określoną sekcję kodu do debugowania. W tym celu importujemy bibliotekę pdb i używamy set_trace (), aby przerwać przepływ tego problematycznego kodu przykładowego.

import pdb

def divide(a, b):
    pdb.set_trace()
    return a/b 
    # What's wrong with this? Hint: 2 != 3

print divide(1, 2)

Uruchomienie tego programu uruchomi interaktywny debugger.

python foo.py 
> ~/scratch/foo.py(5)divide()
-> return a/b
(Pdb) 

Często to polecenie jest używane w jednym wierszu, więc można je skomentować za pomocą jednego znaku #

 import pdf; pdb.set_trace()

W wierszu polecenia (Pdb) można wprowadzić polecenia. Te polecenia mogą być poleceniami debuggera lub pythonem. Aby wydrukować zmienne, możemy użyć p z debuggera lub print Pythona.

(Pdb) p a
1
(Pdb) print a
1

Aby zobaczyć listę wszystkich zmiennych lokalnych użyj

locals

funkcja wbudowana

Są to dobre polecenia debugowania, które należy wiedzieć:

b <n> | <f>: set breakpoint at line *n* or function named *f*.
# b 3
# b divide
b: show all breakpoints.
c: continue until the next breakpoint.
s: step through this line (will enter a function).
n: step over this line (jumps over a function).
r: continue until the current function returns.
l: list a window of code around this line.
p <var>: print variable named *var*.
# p x
q: quit debugger.
bt: print the traceback of the current execution call stack
up: move your scope up the function call stack to the caller of the current function
down: Move your scope back down the function call stack one level
step: Run the program until the next line of execution in the program, then return control back to the debugger
next: run the program until the next line of execution in the current function, then return control back to the debugger
return: run the program until the current function returns, then return control back to the debugger
continue: continue running the program until the next breakpoint (or set_trace si called again)

Debuger może także interaktywnie oceniać Pythona:

-> return a/b
(Pdb) p a+b
3
(Pdb) [ str(m) for m in [a,b]] 
['1', '2']
(Pdb) [ d for d in xrange(5)]
[0, 1, 2, 3, 4]

Uwaga:

Jeśli którakolwiek z nazw zmiennych pokrywa się z poleceniami debuggera, użyj wykrzyknika „ ! 'przed var, aby wyraźnie odwoływać się do zmiennej, a nie polecenia debuggera. Na przykład często zdarza się, że używasz nazwy zmiennej „ c ” jako licznika i możesz chcieć wydrukować ją podczas debuggera. proste polecenie „ c ” kontynuowałoby wykonywanie do następnego punktu przerwania. Zamiast tego użyj „ ! C ”, aby wydrukować wartość zmiennej w następujący sposób:

(Pdb) !c
4

Przez IPython i ipdb

Jeśli zainstalowano IPython (lub Jupyter ), debugger można wywołać za pomocą:

import ipdb
ipdb.set_trace()

Po osiągnięciu kod wyjdzie i wydrukuje:

 /home/usr/ook.py(3)<module>()
      1 import ipdb
      2 ipdb.set_trace()
----> 3 print("Hello world!")

ipdb>

Oczywiście oznacza to, że należy edytować kod. Istnieje prostszy sposób:

from IPython.core import ultratb
sys.excepthook = ultratb.FormattedTB(mode='Verbose',
                                     color_scheme='Linux',
                                     call_pdb=1)

Spowoduje to wywołanie debuggera, jeśli podniesiony zostanie nieprzechwycony wyjątek.

Zdalny debugger

Czasami trzeba debugować kod Pythona, który jest wykonywany przez inny proces iw takich przypadkach rpdb jest rpdb .

rpdb to opakowanie wokół pdb, które przekierowuje stdin i stdout do modułu obsługi gniazda. Domyślnie otwiera debugger na porcie 4444

Stosowanie:

# In the Python file you want to debug.
import rpdb
rpdb.set_trace()

Następnie musisz uruchomić to w terminalu, aby połączyć się z tym procesem.

# Call in a terminal to see the output
$ nc 127.0.0.1 4444

I dostaniesz pdb promt

> /home/usr/ook.py(3)<module>()
-> print("Hello world!")
(Pdb)


Modified text is an extract of the original Stack Overflow Documentation
Licencjonowany na podstawie CC BY-SA 3.0
Nie związany z Stack Overflow