A Python implementation of the BioPAX object model, and parts of PaxTools.
Project description
PyBioPAX: A python implementation of the BioPAX object model
PyBioPAX implements the BioPAX level 3 object model (http://www.biopax.org/release/biopax-level3-documentation.pdf) as a set of Python classes. It exposes API functions to read OWL files into this object model, and to dump OWL files from this object model. This allows for the processing and creation of BioPAX models natively in Python.
Gyori BM, Hoyt CT (2022). PyBioPAX: biological pathway exchange in Python. Journal of Open Source Software, 7(71), 4136, https://doi.org/10.21105/joss.04136
Installation
PyBioPAX can be installed from PyPI as a package:
$ pip install pybiopax
Usage
Reading an OWL file into a BioPaxModel object:
import pybiopax
model = pybiopax.model_from_owl_file('test.owl')
Writing a BioPaxModel into an OWL file:
import pybiopax
pybiopax.model_to_owl_file(model, 'test.owl')
Querying Pathway Commons to get a BioPaxModel object:
import pybiopax
model = pybiopax.model_from_pc_query('pathsfromto', ['MAP2K1'], ['MAPK1'])
Working with the elements of the Python object model:
import pybiopax
model = pybiopax.model_from_pc_query('pathsfromto', ['MAP2K1'], ['MAPK1'])
# Each BioPaxModel instance has an objects attribute which is a dict
# whose keys are object URIs (strings) and values are BioPaxObject instances.
assert isinstance(model.objects, dict)
assert all(isinstance(obj, pybiopax.biopax.BioPaxObject)
for obj in model.objects.values())
# Let's look at a specific object
bcr = model.objects['BiochemicalReaction_4f689747397d98089c551022a3ae2d88']
# This is a BiochemicalReaction which has a left and a right side. All list/set
# types per the BioPAX specification are represented as lists in the Python
# object model
# Both left and right consist of a single protein
left = bcr.left[0]
assert isinstance(left, pybiopax.biopax.Protein)
assert left.display_name == 'ERK1-2'
right = bcr.right[0]
assert isinstance(right, pybiopax.biopax.Protein)
assert right.display_name == 'ERK1-2-active'
We can also use the pybiopax.paths
module to construct iterators over
objects based on a string specification from a given starting point.
Continuing from the block of code above, we take the BiochemicalReaction
bcr
and link to reactants on its left hand side, then linking to their
entity references, and finally linking back to all the physical entities
that those are references of.
from pybiopax.paths import find_objects
erks = find_objects(bcr, 'left/entity_reference/entity_reference_of')
Contribution and support
To contribute to the code, please submit a pull request after reading the contribution guidelines. To report bugs and issues, or ask questions related to PyBioPAX, please submit an issue.
Funding
Development of this software was supported by the Defense Advanced Research Projects Agency under award W911NF-15-1-0544 and the National Cancer Institute under award U54-CA225088.
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 pybiopax-0.1.5.tar.gz
.
File metadata
- Download URL: pybiopax-0.1.5.tar.gz
- Upload date:
- Size: 3.7 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.13
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 0e0bf410592c36c32c0428d8f64fca65aac69293859b0d233815ae62ceca547c |
|
MD5 | 9e451905e323ce8c325aaddf7c0fefb2 |
|
BLAKE2b-256 | 0c174288bc531ab56e177894b7064b28fc0da844b25b0bfd4225e764cde80f76 |
Provenance
File details
Details for the file pybiopax-0.1.5-py3-none-any.whl
.
File metadata
- Download URL: pybiopax-0.1.5-py3-none-any.whl
- Upload date:
- Size: 24.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.13
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 8f75ce10af61d0909f77b0cb178eeacc718976bd5e3368dc57d9bc5335d54d90 |
|
MD5 | 4e5324a0522db163467fbdacb9004748 |
|
BLAKE2b-256 | 59910b2b61b643f9c8aecbc9fca8063c617ac5be69614264c86b954d4e65fdf3 |