Skip to main content

Naturalis BioInformatics ToolKit

Project description

nbitk: Naturalis BioInformatics ToolKit

This project is intended as a foundational toolkit for bioinformatics research at Naturalis Biodiversity Center. The toolkit is written in Python and is designed to be easy to use and easy to extend.

Who is this for?

The principal users and developers of this toolkit are the bioinformaticians at Naturalis Biodiversity Center. In addition, developers and data engineers of Naturalis's Core Sequence Cloud use some of the functionality to enact service calls for data validation. Lastly, researchers may find this toolkit useful for operating on biodiversity data, access remote services, and run command line tools via wrappers. Design changes and feature requests should therefore be discussed with the bioinformatics team.

Installation from PyPI

The toolkit and its python dependencies can be installed from PyPI. This results in a lightweight installation that has only the python stack but not any command line tools. This is typically what you need when running service clients. The install is as follows:

pip install nbitk

Installation from BioConda

In addition, there is a release on BioConda, that additionally includes any command line tools for which the toolkit contains wrappers. That release can also be installed directly, resulting in both the core python toolkit as well as command line tools (i.e. you do NOT have to do both pip and conda, just one or the other dependening on whether you need to run command line tools, for which you would use the conda release). This is installed as follows:

conda install nbitk

NOTE: the environment.yml is here for the unit testing pipeline so that tool wrappers can be tested as well. Its only other use is to help prepare an updated release on BioConda. Otherwise there is no end-user function for it.

Preparing releases

PyPI

To release on PyPI, all that needs to happen is to tag a version, and then the release is pushed out automatically. Things to keep in mind:

  • Ensure that the release is of sufficient quality (coding style, comments, pydoc, all tests pass)
  • Use semantic versioning to tag the release

BioConda

To release on BioConda, an overview of the steps involved is as follows:

  1. Fork the BioConda recipes repo
  2. Update the recipes/nbitk/meta.yml in your fork, specifically:
    • Update the version number
    • Update the run requirements to include everything from the pyproject.toml and environment.yml
    • Update the SHA256 hash to match that version. The easiest way to obtain this is to go to https://pypi.org/project/nbitk/#files and click on 'view details' for the release.
  3. Post a pull request to BioConda, with 'Update nbitk' in the title
  4. Address any problems detected by BioConda's CI tools
  5. If all is fine, tag the PR thread for review by a human, and wait
  6. Once a human shows up, address their feedback (be nice: they're volunteers!)
  7. When the human is happy, they will merge the update into BioConda

Usage

The toolkit is meant for programmatic use. It is not intended to be used as a command line tool. Consult the various modules and classes for documentation on how to use the toolkit. In addition, the scripts in the tests directory provide examples of how to use the toolkit.

License

This project is licensed under the Apache 2.0 License - see the LICENSE file for details.

Contributing

Please read CONTRIBUTING.md for details on our code of conduct, and the process for submitting pull requests to us.

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

nbitk-0.5.2.tar.gz (10.4 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

nbitk-0.5.2-py3-none-any.whl (10.9 MB view details)

Uploaded Python 3

File details

Details for the file nbitk-0.5.2.tar.gz.

File metadata

  • Download URL: nbitk-0.5.2.tar.gz
  • Upload date:
  • Size: 10.4 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.9.22

File hashes

Hashes for nbitk-0.5.2.tar.gz
Algorithm Hash digest
SHA256 cbfc3b59381d135afd0216ae0ba31645fb68a1c8a21130ae7c7955e96779c3af
MD5 8f5e9a03b879668a4845d48606f152cc
BLAKE2b-256 3468d032e9c149a0c6d616d830f939ebee34fd9cd5269e8de1e3083a17c94cb7

See more details on using hashes here.

File details

Details for the file nbitk-0.5.2-py3-none-any.whl.

File metadata

  • Download URL: nbitk-0.5.2-py3-none-any.whl
  • Upload date:
  • Size: 10.9 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.9.22

File hashes

Hashes for nbitk-0.5.2-py3-none-any.whl
Algorithm Hash digest
SHA256 5d65ddbb80a89497bb6d73d71cf4d6f7a3f5ba141cb0d600b8fc5fa9cccedd20
MD5 ab85977cf8ab54f7e283a54e784a88ed
BLAKE2b-256 ef307fcb82ba720c26bf870e1d16f3dd6c79fecb26a6fcac947e7d8a97277abb

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page