-
Notifications
You must be signed in to change notification settings - Fork 1.2k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Support fully integrated IPython terminal #22139
Comments
Thanks for the feature request! We are going to give the community 60 days from when this issue was created to provide 7 👍 upvotes on the opening comment to gauge general interest in this idea. If there's enough upvotes then we will consider this feature request in our future planning. If there's unfortunately not enough upvotes then we will close this issue. |
See also #17172. I'd also like to be able to use IPython instead of the regular interactive Python interpreter. |
I'd also like to be able to use IPython instead of the regular interactive Python interpreter. |
Thanks for the feature request! We are going to give the community 60 days from when this issue was created to provide 7 👍 upvotes on the opening comment to gauge general interest in this idea. If there's enough upvotes then we will consider this feature request in our future planning. If there's unfortunately not enough upvotes then we will close this issue. |
BTW please let us know what you specifically miss from IPython. |
Magic commands and colored input and output :) |
I'd also add the ability to run shell commands (e.g. |
terminal functionality such as completions |
Ditto for syntax highlighting and code completions. If possible, it would also be amazing if |
I'm new to VSCode (coming here from Spyder because work uses VSCode), so apologies if these sorts of functionalities are available and I just haven't found them yet (and yes, I know that the debug console is a thing and some of the stuff I'm going to list can sort of be approximated in the debug console). Here's my list of the main things I find useful about the iPython console in Spyder:
|
That won't work as it isn't designed for that. Are you not using our REPL support, which supports sending multi-line code, because it lacks a variable viewer? |
@brettcannon Thanks for the response. To be honest, I'm very new to VSCode, so I wasn't aware that REPL support was a thing. But yes, the lack of a variable viewer would be somewhat annoying. |
hello @brettcannon, My use case for IPython is launching a debug session with IPython. The Databricks VSCode extension adds an IPython startup script that sets some environment variables and initializes a Spark session. However, when using the default VSCode Python debugger, which is a standard Python interpreter rather than the IPython one, the IPython startup script is not executed. I tried this config in {
"version": "0.2.0",
"configurations": [
{
"name": "IPython Debugger: Current File",
"type": "debugpy",
"request": "launch",
"program": "${file}",
"console": "integratedTerminal",
"python": "${workspaceFolder}/.venv/bin/ipython"
}
]
} |
/cc @anthonykim1 |
Thanks everyone for showing interest in this. As I mentioned #17172 (comment), I'd like to know what folks think about the new Native REPL and get some feedback on what specific features folks really want from iPython in terminal. |
I have to say that I stopped using IPython, because the new REPL in Python 3.13 is good enough for me. I'd prefer using that over the Native REPL, since a terminal-based REPL has been the go-to method for interactive computing for me, as it is also available in many other languages. Therefore, I'd rather have a good terminal REPL experience than a custom "native" REPL (but unfortunately there are still a couple of issues, such as the indentation issue on Windows, the fact that running the entire script and running single lines/selections in the REPL use the same terminal, etc.). |
Thanks @anthonykim1 for asking about this! This might be slightly off-topic but I wanted to say that I'm still struggling to understand the motivation behind the native REPL. I've been a VS Code Python user for many years, and I have two distinct use cases for running my code:
The first case is already covered through using code cells together with the Interactive Python window. The second case is covered by the Run button, which spawns a Python interpreter on the command line and runs my code. I don't understand which use case the native REPL is addressing -- maybe because I'm not in the target audience? What's the goal here? I see it can spawn an interactive-window-like experience without requiring a Jupyter kernel, but I don't see how this brings me any advantages either? I've got plenty of SSD storage, and dev-only dependencies (for interactive development) are declared as such, so they won't get deployed after development has been finished and we go into production. Would you be so kind as to help me understand what the native REPL is all about? I know for a fact that several of my friends and colleagues -- all faithful users of VS Code for many years now!! -- feel the same: they're confused and hence don't use the native REPL at all so far. Thank you so much for your input! Richard |
Thanks @cbrnr @hoechenberger for your valuable feedbacks. I truly appreciate them. After couple months of launching native REPL we also do see portion of users favoring terminal REPL over native REPL, and also vice versa. We do recognize the native REPL can be very opinionated product in terms of its positioning. That being said, we are not planning to discard REPL in terminal, but are aiming to provide best REPL experience for people in both category (whether they enjoy REPL in terminal or in Editor via Native REPL) Some of the motivation behind creation of Native REPL was to provide features that were originally only available in the higher fidelity Jupyter Notebook or via inside the Editor. These include features such as Intellisense, Syntax Highlighting. I do think these features can go into REPL in terminal and lot of folks who still favor REPL in terminal experience would benefit from this (check out terminal suggest for different shell types atm) eventually :) |
The Python IDE Spyder runs code in an IPython terminal integrated in the IDE. The IPython terminal opens along with the rest of the IDE and when you run a script, it gets run directly via
%run
in existing IPython terminal. The terminal remains open after execution of a script so that you can access variables in its context afterwards.I sorely miss this feature in VSCode and it would be absolutely great if this could be offered by the Python extension. Spyder is open source, so it should be possible to see how they have implemented it.
The text was updated successfully, but these errors were encountered: