Skip to main content

A library for interacting with the Datamint API, designed for efficient data management, processing and Deep Learning workflows.

Project description

Datamint Python API

Build Status Python 3.10+

A comprehensive Python SDK for interacting with the Datamint platform, providing seamless integration for medical imaging workflows, dataset management, and machine learning experiments.

📋 Table of Contents

🚀 Features

  • Dataset Management: Download, upload, and manage medical imaging datasets using intuitive object-based APIs or CLI tools
  • Annotation Tools: Create, upload, and manage annotations (segmentations, labels, measurements) with ease
  • Experiment Tracking: Seamless support for experiment management via MLflow integration
  • PyTorch Lightning Integration: Streamlined machine learning workflows featuring specialized LightningDataModules, built-in trainers (SegmentationTrainer), and automated MLflow checkpoint logging
  • DICOM Support: Native handling of DICOM files, including powerful anonymization capabilities during upload to protect patient privacy
  • Multi-format Support: Robust support for a wide range of medical imaging formats: PNG, JPEG, NIfTI (NIfTI/NRRD), DICOMs and more

See the full documentation at https://sonanceai.github.io/datamint-python-api/

📦 Installation

[!NOTE] We recommend using a virtual environment to avoid package conflicts.

From PyPI

pip install -U datamint

Virtual Environment Setup

Click to expand virtual environment setup instructions

We recommend that you install Datamint in a dedicated virtual environment, to avoid conflicting with your system packages. For instance, create the enviroment once with python3 -m venv datamint-env and then activate it whenever you need it with:

  1. Create the environment (one-time setup):

    python3 -m venv datamint-env
    
  2. Activate the environment (run whenever you need it):

    Platform Command
    Linux/macOS source datamint-env/bin/activate
    Windows CMD datamint-env\Scripts\activate.bat
    Windows PowerShell datamint-env\Scripts\Activate.ps1
  3. Install the package:

    pip install datamint
    

⚙ Setup API key

To use the Datamint API, you need to setup your API key (ask your administrator if you don't have one). Use one of the following methods to setup your API key:

Method 1: Command-line tool (recommended)

Run datamint-config (or python -m datamint config if that doesn't work) in the terminal and follow the instructions. See command_line_tools for more details.

Method 2: Environment variable

Specify the API key as an environment variable.

Bash:

export DATAMINT_API_KEY="my_api_key"
# run your commands (e.g., `datamint-upload`, `python script.py`)

Python:

import os
os.environ["DATAMINT_API_KEY"] = "my_api_key"

📚 Documentation

Resource Description
🚀 Getting Started Step-by-step setup and basic usage
📖 API Reference Complete API documentation
🔥 PyTorch Integration ML workflow integration
🧠 Trainer Guide Built-in trainers, trainer lifecycle, and custom model integration
💡 Examples Practical usage examples

🛠️ Command Line Tools

Full documentation at command_line_tools.

Upload Resources

Upload DICOM files with anonymization:

datamint-upload /path/to/dicoms --recursive --channel "training-data" --publish --tag "my_data_tag"

It anonymizes by default.

Upload resources with segmentations and associate them with a deployed model:

datamint-upload /path/to/dicoms \
   --recursive \
   --segmentation_path /path/to/segmentations \
   --segmentation_names /path/to/segmentation_names.yaml \
   --ai-model "knee-segmentation-v2" \
   --publish

Use --ai-model when uploaded segmentation files should be linked to an existing deployed model by name. --segmentation_names accepts YAML mappings and ITK-SNAP label export CSV/TXT files.

Configuration Management

# Interactive setup
datamint-config

# Set API key
datamint-config --api-key "your-key"

🔒 SSL Certificate Troubleshooting

If you encounter SSL certificate verification errors like:

SSLCertVerificationError: [SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed: unable to get local issuer certificate

Quick Fix

1. Upgrade certifi:

pip install --upgrade certifi

2. Set environment variables:

export SSL_CERT_FILE=$(python -m certifi)
export REQUESTS_CA_BUNDLE=$(python -m certifi)

3. Run your script:

python your_script.py

Alternative Solutions

Option 1: Use Custom CA Bundle

from datamint import Api

api = Api(verify_ssl="/path/to/your/ca-bundle.crt")

Option 2: Disable SSL Verification (Development Only)

from datamint import Api

# ⚠️ WARNING: Only use in development with self-signed certificates
api = Api(verify_ssl=False)

🆘 Support

Full Documentation
GitHub Issues

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

datamint-2.16.0.tar.gz (209.7 kB view details)

Uploaded Source

Built Distribution

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

datamint-2.16.0-py3-none-any.whl (271.9 kB view details)

Uploaded Python 3

File details

Details for the file datamint-2.16.0.tar.gz.

File metadata

  • Download URL: datamint-2.16.0.tar.gz
  • Upload date:
  • Size: 209.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for datamint-2.16.0.tar.gz
Algorithm Hash digest
SHA256 13745aafc7f436dc3b4eae93d6f5fe93c8dfdbdd549fbd6e7c8be0cdb11f28dd
MD5 4990a9d1ad36130c129c708d0088f117
BLAKE2b-256 5d164922b2bbe91dca021bf273c53962d7a7c06064807f3c4ec7335f5c5cdaa9

See more details on using hashes here.

Provenance

The following attestation bundles were made for datamint-2.16.0.tar.gz:

Publisher: release_pypi.yaml on SonanceAI/datamint-python-api

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file datamint-2.16.0-py3-none-any.whl.

File metadata

  • Download URL: datamint-2.16.0-py3-none-any.whl
  • Upload date:
  • Size: 271.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for datamint-2.16.0-py3-none-any.whl
Algorithm Hash digest
SHA256 f10a3f4d3a451b53003b5c7fb312fe77ef237e961689d3b6893930d2232602c5
MD5 b7849b721f4deb0f8abc22333af94849
BLAKE2b-256 1690f1a3155a62d510914c21b30132c8656820d9d1b9238433ceda5c2cfc7d2d

See more details on using hashes here.

Provenance

The following attestation bundles were made for datamint-2.16.0-py3-none-any.whl:

Publisher: release_pypi.yaml on SonanceAI/datamint-python-api

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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