Pants will load a REPL with all of your specified source code and any of its third-party dependencies, which allows you to import those values.
In addition to the default Python shell, Pants supports the improved IPython shell.
To use IPython, run
./pants repl --shell=ipython. To permanently use IPython, add this to your
[repl] shell = "ipython"
You can change IPython's version with
[ipython] version = "ipython>=6.0.0"
If you set the
version lower than IPython 7, then you must set
ignore_cwd = false in the
[ipython] section to avoid Pants setting an option that did not exist in earlier IPython releases.
IPython does not yet work with Pantsd
When using IPython, use the option
--no-pantsdto turn off the Pants daemon, e.g.
./pants --no-pantsd repl --shell=ipython. We are working to fix this.
Python 2 support
Pants uses IPython 7 by default, which does not work with Python 2. You can override
versionto use IPython 5. As mentioned above, you must set
ignore_cwd = false.
[ipython] version = "ipython<6" ignore_cwd = false
You can even use IPython 7 for Python 3 code, and IPython 5 for Python 2 code:
[ipython] version = "ipython==7.16.1 ; python_version >= '3.6'" extra_requirements.add = ["ipython<6 ; python_version == '2.7'"] ignore_cwd = false
$ ./pants repl helloworld/greet/greeting.py Python 3.7.6 (default, Feb 26 2020, 08:28:08) [Clang 11.0.0 (clang-1126.96.36.199)] on darwin Type "help", "copyright", "credits" or "license" for more information. (InteractiveConsole) >>> from helloworld.greet.greeting import Greeter >>> Greeter().greet("Pants") 'buenas tardes, Pants!' >>> from translate import Translator >>> Translator(to_lang="fr").translate("Good morning.") 'Salut.'
This will not load any of your code:
$ ./pants --no-pantsd repl --shell=ipython Python 3.6.10 (default, Feb 26 2020, 08:26:13) Type "copyright", "credits" or "license" for more information. IPython 5.8.0 -- An enhanced Interactive Python. ? -> Introduction and overview of IPython's features. %quickref -> Quick reference. help -> Python's own help system. object? -> Details about 'object', use 'object??' for extra details. In : 21 * 4 Out: 84
Tip: how to exit the REPL
exit()and hit enter, or press
Updated 27 days ago