PyBioPAX: A python implementation of the BioPAX object model
------------------------------------------------------------
[![License](https://img.shields.io/badge/License-BSD%202--Clause-orange.svg)](https://opensource.org/licenses/BSD-2-Clause)
[![DOI](https://joss.theoj.org/papers/10.21105/joss.04136/status.svg)](https://doi.org/10.21105/joss.04136)
[![Build](https://github.com/indralab/pybiopax/workflows/Tests/badge.svg)](https://github.com/indralab/pybiopax/actions)
[![Documentation](https://readthedocs.org/projects/pybiopax/badge/?version=latest)](https://pybiopax.readthedocs.io/en/latest/?badge=latest)
[![PyPI version](https://badge.fury.io/py/pybiopax.svg)](https://badge.fury.io/py/pybiopax)
[![Python 3](https://img.shields.io/pypi/pyversions/pybiopax.svg)](https://www.python.org/downloads/release/python-357/)
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](https://doi.org/10.21105/joss.04136)
Installation
------------
PyBioPAX can be installed from PyPI as a package:
```bash
$ pip install pybiopax
```
Usage
-----
Reading an OWL file into a BioPaxModel object:
```python
import pybiopax
model = pybiopax.model_from_owl_file('test.owl')
```
Writing a BioPaxModel into an OWL file:
```python
import pybiopax
pybiopax.model_to_owl_file(model, 'test.owl')
```
Querying Pathway Commons to get a BioPaxModel object:
```python
import pybiopax
model = pybiopax.model_from_pc_query('pathsfromto', ['MAP2K1'], ['MAPK1'])
```
Working with the elements of the Python object model:
```python
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.
```python
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](https://github.com/indralab/pybiopax/blob/master/CONTRIBUTING.md).
To report bugs and issues, or ask questions related to PyBioPAX, please
submit an [issue](https://github.com/indralab/pybiopax/issues).
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.
Raw data
{
"_id": null,
"home_page": "https://github.com/indralab/pybiopax",
"name": "pybiopax",
"maintainer": null,
"docs_url": null,
"requires_python": null,
"maintainer_email": null,
"keywords": "biology, pathway",
"author": "Benjamin M. Gyori, Harvard Medical School",
"author_email": "benjamin_gyori@hms.harvard.edu",
"download_url": "https://files.pythonhosted.org/packages/0c/17/4288bc531ab56e177894b7064b28fc0da844b25b0bfd4225e764cde80f76/pybiopax-0.1.5.tar.gz",
"platform": null,
"description": "PyBioPAX: A python implementation of the BioPAX object model\n------------------------------------------------------------\n[![License](https://img.shields.io/badge/License-BSD%202--Clause-orange.svg)](https://opensource.org/licenses/BSD-2-Clause)\n[![DOI](https://joss.theoj.org/papers/10.21105/joss.04136/status.svg)](https://doi.org/10.21105/joss.04136)\n[![Build](https://github.com/indralab/pybiopax/workflows/Tests/badge.svg)](https://github.com/indralab/pybiopax/actions)\n[![Documentation](https://readthedocs.org/projects/pybiopax/badge/?version=latest)](https://pybiopax.readthedocs.io/en/latest/?badge=latest)\n[![PyPI version](https://badge.fury.io/py/pybiopax.svg)](https://badge.fury.io/py/pybiopax)\n[![Python 3](https://img.shields.io/pypi/pyversions/pybiopax.svg)](https://www.python.org/downloads/release/python-357/)\n\nPyBioPAX implements the BioPAX level 3 object model (http://www.biopax.org/release/biopax-level3-documentation.pdf) as a set of\nPython classes. It exposes API functions to read OWL files into this\nobject model, and to dump OWL files from this object model.\nThis allows for the processing and creation of BioPAX models natively in\nPython.\n\nGyori 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](https://doi.org/10.21105/joss.04136)\n\nInstallation\n------------\nPyBioPAX can be installed from PyPI as a package:\n\n```bash\n$ pip install pybiopax\n```\n\nUsage\n-----\nReading an OWL file into a BioPaxModel object:\n\n```python\nimport pybiopax\nmodel = pybiopax.model_from_owl_file('test.owl')\n```\n\n\nWriting a BioPaxModel into an OWL file:\n\n```python\nimport pybiopax\npybiopax.model_to_owl_file(model, 'test.owl')\n```\n\nQuerying Pathway Commons to get a BioPaxModel object:\n\n```python\nimport pybiopax\nmodel = pybiopax.model_from_pc_query('pathsfromto', ['MAP2K1'], ['MAPK1'])\n```\n\nWorking with the elements of the Python object model:\n\n```python\nimport pybiopax\nmodel = pybiopax.model_from_pc_query('pathsfromto', ['MAP2K1'], ['MAPK1'])\n\n# Each BioPaxModel instance has an objects attribute which is a dict\n# whose keys are object URIs (strings) and values are BioPaxObject instances.\nassert isinstance(model.objects, dict)\nassert all(isinstance(obj, pybiopax.biopax.BioPaxObject)\n for obj in model.objects.values())\n\n# Let's look at a specific object\nbcr = model.objects['BiochemicalReaction_4f689747397d98089c551022a3ae2d88']\n\n# This is a BiochemicalReaction which has a left and a right side. All list/set\n# types per the BioPAX specification are represented as lists in the Python\n# object model\n# Both left and right consist of a single protein\nleft = bcr.left[0]\nassert isinstance(left, pybiopax.biopax.Protein)\nassert left.display_name == 'ERK1-2'\nright = bcr.right[0]\nassert isinstance(right, pybiopax.biopax.Protein)\nassert right.display_name == 'ERK1-2-active'\n```\n\nWe can also use the `pybiopax.paths` module to construct iterators over\nobjects based on a string specification from a given starting point.\nContinuing from the block of code above, we take the BiochemicalReaction\n`bcr` and link to reactants on its left hand side, then linking to their\nentity references, and finally linking back to all the physical entities\nthat those are references of.\n\n```python\nfrom pybiopax.paths import find_objects\n\nerks = find_objects(bcr, 'left/entity_reference/entity_reference_of')\n```\n\nContribution and support\n------------------------\nTo contribute to the code, please submit a pull request after\nreading the [contribution guidelines](https://github.com/indralab/pybiopax/blob/master/CONTRIBUTING.md).\nTo report bugs and issues, or ask questions related to PyBioPAX, please\nsubmit an [issue](https://github.com/indralab/pybiopax/issues).\n\nFunding\n-------\nDevelopment of this software was supported by the Defense Advanced Research\nProjects Agency under award W911NF-15-1-0544 and the National Cancer Institute\nunder award U54-CA225088.\n",
"bugtrack_url": null,
"license": null,
"summary": "A Python implementation of the BioPAX object model, and parts of PaxTools.",
"version": "0.1.5",
"project_urls": {
"Homepage": "https://github.com/indralab/pybiopax"
},
"split_keywords": [
"biology",
" pathway"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "59910b2b61b643f9c8aecbc9fca8063c617ac5be69614264c86b954d4e65fdf3",
"md5": "4e5324a0522db163467fbdacb9004748",
"sha256": "8f75ce10af61d0909f77b0cb178eeacc718976bd5e3368dc57d9bc5335d54d90"
},
"downloads": -1,
"filename": "pybiopax-0.1.5-py3-none-any.whl",
"has_sig": false,
"md5_digest": "4e5324a0522db163467fbdacb9004748",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": null,
"size": 24045,
"upload_time": "2024-05-10T20:41:46",
"upload_time_iso_8601": "2024-05-10T20:41:46.363394Z",
"url": "https://files.pythonhosted.org/packages/59/91/0b2b61b643f9c8aecbc9fca8063c617ac5be69614264c86b954d4e65fdf3/pybiopax-0.1.5-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "0c174288bc531ab56e177894b7064b28fc0da844b25b0bfd4225e764cde80f76",
"md5": "9e451905e323ce8c325aaddf7c0fefb2",
"sha256": "0e0bf410592c36c32c0428d8f64fca65aac69293859b0d233815ae62ceca547c"
},
"downloads": -1,
"filename": "pybiopax-0.1.5.tar.gz",
"has_sig": false,
"md5_digest": "9e451905e323ce8c325aaddf7c0fefb2",
"packagetype": "sdist",
"python_version": "source",
"requires_python": null,
"size": 3651412,
"upload_time": "2024-05-10T20:41:48",
"upload_time_iso_8601": "2024-05-10T20:41:48.421682Z",
"url": "https://files.pythonhosted.org/packages/0c/17/4288bc531ab56e177894b7064b28fc0da844b25b0bfd4225e764cde80f76/pybiopax-0.1.5.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-05-10 20:41:48",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "indralab",
"github_project": "pybiopax",
"travis_ci": false,
"coveralls": false,
"github_actions": true,
"tox": true,
"lcname": "pybiopax"
}