Issue
The essence:
Using Spyder, it's possible to run parts of code by highlighting it and clicking F9. This works with For Loops as well, but the problem (for me at least) is that it seems impossible to run the selected part step by step. I find this a bit strange since it's possible to run For Loops step by step under other cirmustances (and inspect the state of the variables at each step).
Allow me to explain:
The snippet below is an operation on two variables names = ['A', 'B', 'C']
and values = [11,12,13]
using a For Loop. In order to give a proper description of what I'm unable to do with this setup, I feel it's necessary to explain what I am able to do and also why I think the whole thing is a bit strange if it turns out that what I would like to do is in fact impossible.
I often find myself messing around with a lot of variables using different routines. The problem I'm facing is that in order to debug these routines, I often have to re-run parts of the code that redefine all my variables before I'm actually able to look for bugs in other parts of the code. And THAT'S why it would be great to be able run a stepwise debugging of a For Loop on pre-existing variables that I can inspect in Spyders Variable explorer. I'm mostly messing around with Python in Spyder, but please suggest other IDEs where this may be possible.
Here's an example:
def foo():
names = ['A', 'B', 'C']
values = [11,12,13]
i = 0
for n in names:
variable = str(n) + ' = ' + str(values[i])
print(variable)
i += 1
foo()
Below are my options (if the issue seems clear enough, you can easily jump to the last part Option 5):
Option 1 - Run code using Run file (F5):
This unsurprisingly prints the following in the IPython console:
A = 11
B = 12
C = 13
The rest of the environment looks like below. Notice that it doesn't leave any variables in memory and/or to be inspected in the Variable explorer. That's good for memory management, but bad for a small scale wanna-be programmer that doesn't care about these things.
Option 2 - Forget the function and just Run file
Commenting out def foo()
and foo()
and clicking Run file (F5) (also fixing the indentation) prints the same thing to the IPython console AND leaves the variables behind in the Variable explorer for further inspection.
The edited code:
#def foo():
names = ['A', 'B', 'C']
values = [11,12,13]
i = 0
for n in names:
variable = str(n) + ' = ' + str(values[i])
print(variable)
i += 1
#foo()
The environment:
Notice that the Variable explorer shows the state of each variable after the execution of the code.
Option 3 - Same code as option 2 now using Debug File (Cltr+F5) and Run Current Line (Ctrl+F10)
Clicking Debug File (Cltr+F5) will let me start at the beginning of the routine, and step through it line by line using Run Current Line (Ctrl+f10). Including the lines in the For Loop. At each step, I can easily inspect the state of the variables as they change in the Variable explorer.
The environment after stepping through the For Loop one time:
To a non-professional programmer like myself, this would look like the easiest and most basic way of both writing and debugging code. However, It's hard to avoid the benefits of wrapping code into functions for greater re-useability. So, back to foo()
again:
Option 4 - Debug function with Debug File (Cltr+F5), Continue Execution Until Next Breakpoint (Ctrl+F12) and Step Into Function or Method of current line (Ctrl+F11) and Run Current Line (Ctrl+F10).
Using Debug File (Cltr+F5) initiates the debugging and highlights line 2. To progress, I can use Continue Execution Until Next Breakpoint (Ctrl+F12) which halts the execution at line 11. Here I can choose to Run Current Line (Ctrl+f10) which calls the function without any more fuzz, or I can Step Into Function or Method of current line (Ctrl+F11) which brings me to my happy place. Now I can Run Current Line (Ctrl+F10) to define the variables, and even inspect the variables in the For Loop step by step in the Variable explorer. Here's the environment after defining the variables within the function and stepping through the For Loop one time:
So what was the question again??
Option 5 - Debug a for Loop using existing varibles
In Spyder, you can run parts of code simply by highlighting it and using Run Selection or Current Line (F9) without even defining the function. So starting from scratch, I can define my variables simply by selecting them and clicking F9. Now they're available in the Variable explorer for further inspection:
You can do the same thing with the rest of the code. The For Loop
is run in its entirety and the variables become available in the Variable explorer.
And now, finally, we arrive at the main question. Is it in any way possible to run through the highlighted For Loop step by step instead of the whole thing at the same time like in Option 1? (And without having to run through the function, stop at a breakpoint and continue using F10 like described in Option 4?)
Ideally, it would be as simple as highlighting the code and do something like Stepwise debug selected code (Ctrl'??) and that's it.
I hope this makes sense to some of you. And please let me know if this approach is just completely wrong from start to finish!
Thank you!
Edit: Adding a breakpoint before running the selected part with F9 has no effect:
Edit 2 - System info:
- Windows 7
- Python 3.6.0 Anaconda custom (64-bit)
- Spyder 3.2.5
Solution
(Spyder maintainer here) There is a trick not many people know to introduce breakpoints wherever you want in your Python code: import pdb; pdb.set_trace()
.
In your case, you need to replace your code with
def foo():
names = ['A', 'B', 'C']
values = [11,12,13]
i = 0
import pdb; pdb.set_trace()
for n in names:
variable = str(n) + ' = ' + str(values[i])
print(variable)
i += 1
foo()
and then run your file with Run file
/F5 or also as a cell with Ctrl + Enter. With this simple change you'll get a debugger session exactly at the line pdb.set_trace()
is placed and enter the for
cycle below it to iterate line by line through it.
Note: Since Python 3.7 this is even simpler because it adds a new builtin function called breakpoint
to replace pdb.set_trace()
, but with the exact same effect.
Answered By - Carlos Cordoba
0 comments:
Post a Comment
Note: Only a member of this blog may post a comment.