Debugger#
Debugging in Spyder is supported through integration with the enhanced ipdb
debugger in the IPython Console.
This allows breakpoints and the execution flow to be viewed and controlled right from the Spyder GUI, as well as with all the familiar IPython console commands.
data:image/s3,"s3://crabby-images/ada09/ada099778b5b30a6c138e0d805c968e61f45a0bb" alt="A Spyder IPython console window, showing the ipdb debugger in action"
Debugging with ipdb#
You can fully control debugger execution from the Debug menu, Debug toolbar and via configurable keyboard shortcuts, along with the standard ipdb
console commands.
data:image/s3,"s3://crabby-images/ff23c/ff23cb7fcd6743f52a3df22e3cf6b16086db2325" alt="A Spyder IPython console window, showing debugging from toolbar"
Additionally, the Editor shows the line of code the debugger is currently stopped on with an arrow.
data:image/s3,"s3://crabby-images/eb5a2/eb5a29b97cb7a27ced71948f4331ddee277aa3a0" alt="Spyder Editor showing the debugging panel"
Spyder’s debugger offers syntax highlighting, code completion and command history, which work exactly like they do in the normal interactive interpreter.
Use the up and down arrows to recall previous commands, and press Tab to trigger autocomplete suggestions.
data:image/s3,"s3://crabby-images/349dd/349dd425e24fb6df456ab636aae037bd81629b36" alt="A Spyder IPython console window, showing autocompletion when debugging"
Furthermore, IPython’s magic functions are available in debugging mode.
You can, for example, run %ls
to list the contents of your current working directory or %timeit
to check how fast a given snippet of code is.
data:image/s3,"s3://crabby-images/69ffb/69ffb3efd58d3aba55f8252b9eb54e2f74ff6845" alt="Ipython console in debug mode showing timeit magic"
Finally, you can enter and execute multiline statements in Spyder’s debugger just like with the regular IPython prompt, to easily run complex code.
data:image/s3,"s3://crabby-images/260f7/260f7cf2e87c096cb3c227a61600a351ea3bceed" alt="Debugger showing multiline debugger"
Breakpoints#
Spyder’s debugger is integrated with the Breakpoints pane, which lists the file, line, and condition (if any) of every breakpoint defined. To open it, select , or press Ctrl-Shift-B (Cmd-Shift-B on macOS).
data:image/s3,"s3://crabby-images/b9ac9/b9ac910843f9fb234344751da2010cb411049b9d" alt="Spyder's Breakpoints panel, with a number of examples showing file, line number and an optional condition"
There are several different ways to set and clear breakpoints:
With the Set/clear breakpoint option in the Debug menu.
Through pressing the configurable keyboard shortcut (F12 for normal, or Shift-F12 for conditional breakpoints by default).
By clicking to the left of the line number in an open file in the Editor (adding Shift for a conditional breakpoint).
With the
breakpoint()
builtin function in your code.Interactively, using the
b
command in a debugging session.
data:image/s3,"s3://crabby-images/98901/98901e513e665a4d835776a29b6f3ed5542afcf0" alt="Spyder showing setting conditional breakpoint"
You can access and edit local and global variables at each breakpoint through the Variable Explorer.
data:image/s3,"s3://crabby-images/a3d1a/a3d1a7ab34adc9c87e26577c6d8cb4194718b13f" alt="Spyder's console and variable explorer showing local and global variables when debugging"
Advanced features#
You can avoid stepping through other Python packages while debugging by enabling the new Ignore Python libraries while debugging option in Spyder’s preferences, under . This will skip all the built-in and third-party Python modules you have installed.
data:image/s3,"s3://crabby-images/bfda3/bfda30eee04c39a04657fe0abb2330102be95373" alt="Spyder's preferences showing Ignore Python libraries while debugging options"
If your code has variables with the same names as Pdb commands (e.g. b
or step
), you can still refer to them as normal while debugging.
To call the respective Pdb command, just add an exclamation point before it (e.g. !b
or !step
).
data:image/s3,"s3://crabby-images/f8839/f8839e59ff9dd60eb290b379dd8999de5863445c" alt="Spyder's IPython console showing Pdb commands"
You can have Spyder automatically execute a custom snippet of code every time the debugger stops. For example, you can use this to set specific variables, or import commonly-used modules so they are always available while debugging. To set this up, go to
, and enter the code that you want to be executed with each step.data:image/s3,"s3://crabby-images/5bcfa/5bcfab48ac8a1fd188b036463e5bc1b61c61a37b" alt="Spyder's preferenes with debugging snippet"
Matplotlib support#
Generating Matplotlib figures is fully supported while the debugger is active, including all the different graphics backends.
Use the %matplotlib
magic to change to an interactive backend (e.g. %matplotlib qt5
) to pan, zoom and adjust your plots in a separate window, or switch back to the default inline
(%matplotlib inline
) to see them displayed right in the Plots pane.
data:image/s3,"s3://crabby-images/f978e/f978e76a913744521c67effd80a0e04137167ce4" alt="Debugger showing matplotlib interactive backend"
To avoid showing plots while debugging, deactivate the Process execute events while debugging option in .