Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/synbiodex/sbol-utilities
Command-line utilities and scripts for manipulating SBOL data
https://github.com/synbiodex/sbol-utilities
Last synced: 4 days ago
JSON representation
Command-line utilities and scripts for manipulating SBOL data
- Host: GitHub
- URL: https://github.com/synbiodex/sbol-utilities
- Owner: SynBioDex
- License: mit
- Created: 2021-04-08T19:45:19.000Z (almost 4 years ago)
- Default Branch: develop
- Last Pushed: 2024-09-03T16:14:36.000Z (4 months ago)
- Last Synced: 2024-12-11T12:30:53.202Z (about 1 month ago)
- Language: JavaScript
- Size: 7.57 MB
- Stars: 15
- Watchers: 11
- Forks: 21
- Open Issues: 119
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE.txt
Awesome Lists containing this project
README
# SBOL-utilities
SBOL-utilities is a collection of scripts and functions for manipulating SBOL 3 data that can be run from the command line or as functions in Python.
[Additional documentation is online at readthedocs.io](https://sbol-utilities.readthedocs.io/en/latest/).[![Documentation Status](https://readthedocs.org/projects/sbol-utilities/badge/?version=latest)](http://sbol-utilities.readthedocs.io/)
[![Docstrings Coverage](https://github.com/SynBioDex/SBOL-utilities/actions/workflows/docstr-coverage.yml/badge.svg)](https://github.com/SynBioDex/SBOL-utilities/actions/workflows/docstr-coverage.yml)
[![PyPI version fury.io](https://badge.fury.io/py/sbol-utilities.svg)](https://pypi.python.org/pypi/sbol-utilities/)
[![PyPI license](https://img.shields.io/pypi/l/sbol-utilities.svg)](https://pypi.python.org/pypi/sbol-utilities/)
[![PyPI pyversions](https://img.shields.io/pypi/pyversions/sbol-utilities.svg)](https://pypi.python.org/pypi/sbol-utilities/)
[![gh-action badge](https://github.com/SynBioDex/SBOL-utilities/actions/workflows/python-app.yml/badge.svg)](https://github.com/SynBioDex/SBOL-utilities/actions)## Installation
SBOL utilities requires Python 3.7+.
To install the package and all dependences, run:
```
pip3 install sbol-utilities
```Certain utilities also have non-Python dependencies, which must be installed separately:
- `graph-sbol` requires [Graphviz](https://graphviz.org/) to be able to render diagrams.
- `sbol-converter` requires [node.js](https://nodejs.org/en/) to be able to locally run Javascript.## Utilities
### Graph SBOL Documents
The `graph_sbol` utility uses graphviz to render the object tree in an sbol Document. In addition it will write PDF and Graphviz source files.
To use in context of an application:
```
import sbol3
from sbol_utilities.graph_sbol import graph_sboldoc = sbol3.Document()
doc.read('my_file.ttl')
graph_sbol(doc)
```To run as a commandline executable:
```
graph-sbol -i my_file.ttl
```### Convert an Excel template file to SBOL
The `excel-to-sbol` utility reads an Excel file specifying a library of basic and composite parts, formatted following `sbol_library_template.xlsx`.
### Convert beween SBOL3 and other genetic design formats
The `sbol-converter` utility converts between any of the SBOL3, SBOL2, GenBank, and FASTA formats.
Additional "macro" utilities convert specifically between SBOL3 and one of the other formats:
- `sbol-to-fasta` and `fasta-to-sbol` convert from SBOL3 to FASTA and vice versa
- `sbol-to-genbank` and `genbank-to-sbol` convert from SBOL3 to GenBank and vice versa
- `sbol3-to-sbol2` and `sbol2-to-sbol3` convert to and from SBOL2### Expand the combinatorial derivations in an SBOL file
The `sbol-expand-derivations` utility searches through an SBOL file for CombinatorialDerivation objects and expands them to create a library of all of the specific constructs.
### Calculate sequences of DNA components in an SBOL file
The `sbol-calculate-sequences` utility attempts to calculate the sequence of any DNA Component that can be fully specified from the sequences of its sub-components.
### Calculate sequence synthesis complexity for DNA sequences in an SBOL file
The `sbol-calculate-complexity` utility attempts to calculate the synthesis complexity of any DNA sequence in the file, by sending sequences to be evaluated by IDT's sequence calculator service. Sequences whose complexity is known are not re-calculated.
The system uses the gBlock API, which is intended for sequences from 125 to 3000 bp in length. If it is more than 3000 bp or less than 125 bp your returned score will be 0. A complexity score in the range from 0 to 10 means your sequence is synthesizable, if the score is greater or equal than 10 means it is not synthesizable.
Note that use of this utility requires an account with IDT that is set up to use IDT's online service API (see: https://www.idtdna.com/pages/tools/apidoc)
### Compute the difference between two SBOL3 documents
The `sbol-diff` utility computes the difference between two SBOL3 documents
and reports the differences.## Contributing
We welcome contributions that patch bugs, improve existing utilities or documentation, or add new utilities!
For guidance on how to contribute effectively to this project, see [CONTRIBUTING.md](CONTRIBUTING.md).