Skip to main content

Converts to ASM (Allotrope Simple Model) from various file formats.

Project description

*Allotrope® is a registered trademark of the Allotrope Foundation; no affiliation with the Allotrope Foundation is claimed or implied.

Introduction

Welcome to allotropy -- a Python library by Benchling for converting instrument data into the Allotrope Simple Model (ASM).

View the list of instrument software currently supported in SUPPORTED_INSTRUMENT_SOFTWARE.

The objective of this library is to read text or Excel based instrument software output and return a JSON representation that conforms to the published ASM schema. Note that some schemas do not yet match the published ASM schema, in these cases the CHANGE_NOTES.md file included alongside the schema details the differences and proposed changes to ASM or the library schema. The code in this library does not convert from proprietary/binary output formats and so has no need to interact with any of the specific vendor softwares.

If you aren't familiar with Allotrope, we suggest you start by reading the Allotrope Product Overview.

We have chosen to have this library output ASM since JSON is easy to read and consume in most modern systems and can be checked by humans without any special tools needed. All of the published open source ASMs can be found in the ASM Gitlab repository.

This code is published under the permissive MIT license because we believe that standardized instrument data is a benefit for everyone in science.

Contributing

We welcome community contributions to this library and we hope that together we can expand the coverage of ASM-ready data for everyone. If you are interested, please read our contribution guidelines.

Usage

Convert a file to an ASM dictionary:

from allotropy.parser_factory import Vendor
from allotropy.to_allotrope import allotrope_from_file

asm_schema = allotrope_from_file("filepath.txt", Vendor.MOLDEV_SOFTMAX_PRO)

or, convert any IO:

from allotropy.parser_factory import Vendor
from allotropy.to_allotrope import allotrope_from_io

with open("filename.txt") as f:
    asm_schema = allotrope_from_io(f, Vendor.MOLDEV_SOFTMAX_PRO)

bytes_io = BytesIO(file_stream)
asm_schema = allotrope_from_io(bytes_io, Vendor.MOLDEV_SOFTMAX_PRO)

Specific setup and build instructions

.gitignore: used standard GitHub Python template and added their recommended JetBrains lines

Setup

Install Hatch: https://hatch.pypa.io/latest/ Install Python: https://www.python.org/downloads/ This library supports Python 3.10 or higher. Hatch will install a matching version of Python (defined in pyproject.toml) when it sets up your environment.

Tell git to use .githooks:

git config core.hooksPath .githooks

Dependencies

To add requirements used by the library, update dependencies in pyproject.toml:

  • For project dependencies, update dependencies under [project].
  • For script dependencies, update dependencies under [tool.hatch.envs.default].
  • For lint dependencies, update dependencies under [tool.hatch.envs.lint].
  • For test dependencies, update dependencies under [tool.hatch.envs.test].

Useful Hatch commands

List all environments:

hatch env show

Run all lint:

hatch run lint:all

Auto-fix all possible lint issues:

hatch run fix

Run all tests in the default python enviroment (currently: 3.11.9)

hatch run test

Run all tests against all supported python versions (currently 3.10-3.12) Note: this is checked against in CI - your change must pass this to merge.

hatch run test_all:test

Run against a specific python version (useful for debugging if a test is failing in one environment)

hatch run test_all.py3.12:test

Run a specific test file (replace the filepath with your own):

hatch run test tests/allotrope/allotrope_test.py

Run all tests with coverage:

hatch run test:cov

Spawn a shell within an environment for development:

hatch shell

Publish

NOTE: only package admins can publish allotropy.

To publish a new version:

hatch run scripts:update-version

Merge the resulting PR, and then run on main:

hatch build
hatch publish

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

allotropy-0.1.64.tar.gz (658.7 kB view details)

Uploaded Source

Built Distribution

allotropy-0.1.64-py3-none-any.whl (867.4 kB view details)

Uploaded Python 3

File details

Details for the file allotropy-0.1.64.tar.gz.

File metadata

  • Download URL: allotropy-0.1.64.tar.gz
  • Upload date:
  • Size: 658.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-httpx/0.27.0

File hashes

Hashes for allotropy-0.1.64.tar.gz
Algorithm Hash digest
SHA256 5db6f6e2aac0d2bf8643544c29f06a4654b576cbcdfd4d260c936243b722df26
MD5 a7edbe6a6764f385fc73c780332bea03
BLAKE2b-256 a9cf0dae685883e0c3b49b7d133ab34807a6f838556058eb7bc2a9cec8f81b63

See more details on using hashes here.

File details

Details for the file allotropy-0.1.64-py3-none-any.whl.

File metadata

  • Download URL: allotropy-0.1.64-py3-none-any.whl
  • Upload date:
  • Size: 867.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-httpx/0.27.0

File hashes

Hashes for allotropy-0.1.64-py3-none-any.whl
Algorithm Hash digest
SHA256 75092d408b308988f1634ccdb7663d58fb020db4d856f3bd5fdc29d76758661a
MD5 32792e83839c1e9bf452e5e819484e93
BLAKE2b-256 c8deb222500c2a65ccec0f223dcd21754d2a44f0b56c0e97eeb7478be36468f6

See more details on using hashes here.

Supported by

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