Python Language
отладка
Поиск…
Отладчик Python: сквозная отладка с помощью _pdb_
Стандартная библиотека Python включает в себя интерактивную библиотеку отладки под названием pdb . pdb обладает широкими возможностями, наиболее часто используемым является способность «пройти» программу.
Для немедленного ввода в пошаговую отладку используйте:
python -m pdb <my_file.py>
Это запустит отладчик в первой строке программы.
Обычно вам нужно настроить таргетинг на определенный раздел кода для отладки. Для этого мы импортируем библиотеку pdb и используем set_trace (), чтобы прервать поток этого проблемного кода примера.
import pdb
def divide(a, b):
pdb.set_trace()
return a/b
# What's wrong with this? Hint: 2 != 3
print divide(1, 2)
Запуск этой программы запустит интерактивный отладчик.
python foo.py
> ~/scratch/foo.py(5)divide()
-> return a/b
(Pdb)
Часто эта команда используется в одной строке, поэтому ее можно прокомментировать одним символом #
import pdf; pdb.set_trace()
В командной строке (Pdb) могут быть введены команды. Этими командами могут быть команды отладчика или python. Для печати переменных мы можем использовать p из отладчика или печати python.
(Pdb) p a
1
(Pdb) print a
1
Чтобы просмотреть список всех локальных переменных, используйте
locals
встроенная функция
Это хорошие команды отладчика, чтобы знать:
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)
Отладчик также может оценивать python в интерактивном режиме:
-> 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]
Замечания:
Если любое из ваших имен переменных совпадает с командами отладчика, используйте восклицательный знак « ! 'перед тем, как var явно ссылается на переменную, а не на команду отладчика. Например, часто бывает так, что вы используете имя переменной « c » для счетчика, и вы можете распечатать его в отладчике. простая команда « c » продолжит выполнение до следующей точки останова. Вместо этого используйте ' ! C ', чтобы напечатать значение переменной следующим образом:
(Pdb) !c
4
Через IPython и ipdb
Если IPython (или Jupyter ) установлены, отладчик можно вызвать, используя:
import ipdb
ipdb.set_trace()
По достижении кода код выхода и выхода:
/home/usr/ook.py(3)<module>()
1 import ipdb
2 ipdb.set_trace()
----> 3 print("Hello world!")
ipdb>
Очевидно, это означает, что нужно редактировать код. Существует более простой способ:
from IPython.core import ultratb
sys.excepthook = ultratb.FormattedTB(mode='Verbose',
color_scheme='Linux',
call_pdb=1)
Это приведет к вызову отладчика, если возникло непокрытое исключение.
Удаленный отладчик
Иногда вам нужно отлаживать код python, который выполняется другим процессом, и в этом случае rpdb
.
rpdb - это оболочка вокруг pdb, которая перенаправляет stdin и stdout в обработчик сокета. По умолчанию он открывает отладчик на порту 4444
Использование:
# In the Python file you want to debug.
import rpdb
rpdb.set_trace()
И тогда вам нужно запустить это в терминале, чтобы подключиться к этому процессу.
# Call in a terminal to see the output
$ nc 127.0.0.1 4444
И вы получите pdb promt
> /home/usr/ook.py(3)<module>()
-> print("Hello world!")
(Pdb)