A simple molecular renderer for the terminal using RDKit.
Project description
TerMol
A simple molecular renderer for the terminal using RDKit.
Table of Contents
Overview
This python package allows for the 2D or 3D rendering of molecules in the terminal, using RDKit and Curses.
Installation
Install TerMol with:
pip install termol
On Windows only, the Curses python package must be installed manually.
Command-Line Usage:
Once installed, you can use the termol
command to render molecules in 2D or 3D.
It takes as input one or more SMILES strings or RDKit compatible molecule files (.sdf, .mol2, separated with spaces. Inputs can also be a text file with one input per line (file or smiles), or a CSV file in the format "name, smiles".
Example usage:
termol "O=C(O)CCCCC(=O)O"
Or:
termol ESR.sdf "O=C4N(Cc1ccccc1)CC(C(=O)NC(Cc2ccccc2)C(O)CNCc3cccc(N(C)C)c3)(N4)Cc5ccccc5" "O=C(O)CCCCC(=O)O"
Additional arguments include:
--names
: The molecule names to be displayed (separated by spaces).--width, --height
: The size of the 'screen' (in number of characters) Default 80x40.--show2D
: Display in 2D instead of 3D.--add_hydrogens
: Have RDKit attempt to add hydrogens automatically. Default False.--timeout
: In the 3D viewer, this will automatically close after this number of seconds. Default None, which allows the viewer to stay open indefinitely.
Controlling the viewer
In the 3D viewer, the molecule will initially rotate about the Y-axis. To change the direction of the rotation, use the arrow keys, or WASD+QE. To pause rotation, hit the spacebar.
To make the molecule smaller or larger, you can use the R and F keys, respectively.
To exit the 3D viewer, hit any other key.
Python Usage:
3D Rendering:
Import the package and call the draw function as shown:
import termol
smiles = "c1cc2c(cc1[N+](=O)[O-])[nH]nn2"
name = "Nitrobenzotriazole"
termol.draw(smiles, name=name)
The molecule input can be a smiles string or an RDKit-compatible filepath (.mol2, .sdf, etc).
2D Rendering:
Sometimes, a simple 2D graphic is sufficient. To render in 2D, use the flag three_d=False
:
termol.draw(smiles, name=name, three_d=False)
Showcase:
To display a showcase of termol's capabilities, you may run:
import termol
termol.showcase()
Want a fun screensaver? Use the timeout=60
argument to cycle through a random molecule every 60 seconds.
Other Options
The draw function only requires the molecule SMILES/file as input. Other options include:
name
: A molecule name to be displayedwidth, height
: The size of the 'screen' (in number of characters) Default 80x40.three_d
: defaults to True to display in 3D. Set to False to print a 2D view.add_hydrogens
: Have RDKit attempt to add hydrogens automatically. Default False.timeout
: In the 3D viewer, this will automatically close after this number of seconds. Default None, which allows the viewer to stay open indefinitely.
termol.draw(input_mol, name=None, width=80, height=40, three_d=True, add_hydrogens=False, timeout=None)
Drawing Many Molecules
The termol.draw_multi()
function takes as input a list of SMILES or molecule files as input, and displays them in succession (In 2D or 3D). If the optional argument names
is provided, it must be the same length as the number of inputs. All other arguments are the same.
License:
This software is provided under the MIT License.
Contact:
Project details
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 termol-0.1.4.tar.gz
.
File metadata
- Download URL: termol-0.1.4.tar.gz
- Upload date:
- Size: 37.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.0 CPython/3.12.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | d1ec62520bd935efe5237422a4e9f4d153e4c57f74cd85db4f3bd084700e9157 |
|
MD5 | 6aa7a30428efe021e6dbf96b694c10f0 |
|
BLAKE2b-256 | 64d51e578b4bace11ec5acc4859cd0619070094e6e987f38613bf5ce3b7973b4 |
File details
Details for the file termol-0.1.4-py3-none-any.whl
.
File metadata
- Download URL: termol-0.1.4-py3-none-any.whl
- Upload date:
- Size: 36.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.0 CPython/3.12.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 8a8bbbe8fc6756991819a0d3350000c70bfc23c0d328e83ac07701851128c237 |
|
MD5 | 3964614ecf6e987f3d9e713170f0b1f7 |
|
BLAKE2b-256 | e36708e1573f86a615d8da2ab18e7f427fe112a46a996017ef509953f540cebb |