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.6.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.6-py3-none-any.whl (10.9 MB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: nbitk-0.5.6.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.6.tar.gz
Algorithm Hash digest
SHA256 186daff53e4dc590e65784090333d6c04b7898c9876ae87a61c560051ae47a85
MD5 dfc906bd2df611247d88ae4a6dff3df7
BLAKE2b-256 8ec2cb6933dc777d6e03a903873c56ac37f63f4081fb58b6b1219d8dfc2bae32

See more details on using hashes here.

File details

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

File metadata

  • Download URL: nbitk-0.5.6-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.6-py3-none-any.whl
Algorithm Hash digest
SHA256 f43c33af6487766c23baf7caf28e2eb2bdb25a862ce92c91c3381809b4bae187
MD5 c78f9c08d3270fbaf9ba165dec5bacf6
BLAKE2b-256 c81f0900021c78f12d81b40d9957a67d26f2c08be63a7ad2e6fa4d470f4a20fc

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