No project description provided
Project description
bpython: A fancy curses interface to the Python interactive interpreter
bpython is a lightweight Python interpreter that adds several features common to IDEs. These features include syntax highlighting, expected parameter list, auto-indentation, and autocompletion. (See below for example usage).
bpython does not aim to be a complete IDE - the focus is on implementing a few ideas in a practical, useful, and lightweight manner.
bpython is a great replacement to any occasion where you would normally use the vanilla Python interpreter - testing out solutions to people’s problems on IRC, quickly testing a method of doing something without creating a temporary file, etc.
You can find more about bpython - including full documentation - at our homepage.
Installation & Basic Usage
Installation using Pip
If you have pip installed, you can simply run:
$ pip install bpython
Start bpython by typing bpython in your terminal. You can exit bpython by using the exit() command or by pressing control-D like regular interactive Python.
Installation via OS Package Manager
The majority of desktop computer operating systems come with package management systems. If you use one of these OSes, you can install bpython using the package manager.
Ubuntu/Debian
Ubuntu/Debian family Linux users can install bpython using the apt package manager, using the command with sudo privileges:
$ apt install bpython
In case you are using an older version, run
$ apt-get install bpython
Arch Linux
Arch Linux uses pacman as the default package manager; you can use it to install bpython:
$ pacman -S bpython
Fedora
Fedora users can install bpython directly from the command line using dnf.
$ dnf install bpython
Windows
Caveats: As bpython makes use of the ncurses library of *nix-family operating systems, bpython on Windows is not officially supported and tested.
However, you may still use bpython on Windows using a workaround. In brief, you should install these two packages using pip:
$ pip install bpython windows-curses
Then you should invoke a program called bpython-curses.exe instead of bpython.exe to use bpython:
$ bpython-curses
Mac OS
Like Windows, Mac OS does not include a package manager by default. If you have installed any third-party package manager like MacPorts, you can install it via
$ sudo port install py-bpython
Features & Examples
Readline-like autocomplete, with suggestions displayed as you type.
In-line syntax highlighting. This uses Pygments for lexing the code as you type, and colours appropriately.
Expected parameter list. As in a lot of modern IDEs, bpython will attempt to display a list of parameters for any function you call. The inspect module (which works with any Python function) is tried first, and then pydoc if that fails.
Rewind. This isn’t called “Undo” because it would be misleading, but “Rewind” is probably as bad. The idea is that the code entered is kept in memory and when the Rewind function is called, the last line is popped and the entire session is re-evaluated. Use <control-R> to rewind.
Edit the current line or your entire session in an editor. F7 opens the current session in a text editor, and if modifications are made, the session is rerun with these changes.
Pastebin code/write to file. Use the <F8> key to upload the screen’s contents to pastebin, with a URL returned.
Reload imported Python modules. Use <F6> to clear sys.modules and rerun your session to test changes to code in a module you’re working on.
Configuration
See the sample-config file for a list of available options. You should save your config file as ~/.config/bpython/config (i.e. $XDG_CONFIG_HOME/bpython/config) or specify at the command line:
bpython --config /path/to/bpython/config
Dependencies
Pygments
curtsies >= 0.3.5
greenlet
pyxdg
requests
Sphinx >= 1.5 (optional, for the documentation)
babel (optional, for internationalization)
jedi (optional, for experimental multiline completion)
watchdog (optional, for monitoring imported modules for changes)
pyperclip (optional, for copying to the clipboard)
bpython-urwid
bpython-urwid requires the following additional packages:
urwid
Known Bugs
For known bugs please see bpython’s known issues and FAQ page.
Contact & Contributing
I hope you find it useful and please feel free to submit any bugs/patches suggestions to Robert or place them on the GitHub issues tracker.
For any other ways of communicating with bpython users and devs you can find us at the community page on the project homepage, or in the community.
Hope to see you there!
CLI Windows Support
Dependencies
Curses Use the appropriate version compiled by Christoph Gohlke.
pyreadline Use the version in the cheeseshop.
Recommended
Obtain the less program from GnuUtils. This makes the pager work as intended. It can be obtained from cygwin or GnuWin32 or msys
Current version is tested with
Curses 2.2
pyreadline 1.7
Curses Notes
The curses used has a bug where the colours are displayed incorrectly:
red is swapped with blue
cyan is swapped with yellow
To correct this I have provided a windows.theme file.
This curses implementation has 16 colors (dark and light versions of the colours)
Alternatives
Feel free to get in touch if you know of any other alternatives that people may be interested to try.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file bpython-0.22.1.tar.gz
.
File metadata
- Download URL: bpython-0.22.1.tar.gz
- Upload date:
- Size: 217.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.5.0 importlib_metadata/4.8.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.10.0rc1+
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 1fb1e0a52332579fc4e3dcf75e21796af67aae2be460179ecfcce9530a49a200 |
|
MD5 | 64d414e563429ab987dc9fa7d9358d91 |
|
BLAKE2b-256 | 625c4039865b7e21c792140ec36411b2999b8ffe98da0f0e79eebad779550868 |
File details
Details for the file bpython-0.22.1-py3-none-any.whl
.
File metadata
- Download URL: bpython-0.22.1-py3-none-any.whl
- Upload date:
- Size: 187.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.5.0 importlib_metadata/4.8.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.10.0rc1+
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 27ab07d64b9f0268990612aa5c1ab7be8705aa819b14b72c9e4b3b0418458937 |
|
MD5 | 2b91137adebd46ef9ea242d5c2dfcf4e |
|
BLAKE2b-256 | 1f803b84b5d13ce5a027f0843d675395d92725f65c234eccbc9505b62cf6ce57 |