Dataset Exchange API Client Library
Project description
DX API Client Library
Welcome to the DX API Client Library! This library provides a convenient Python interface to interact with the DX API, allowing you to manage datasets, installations, and perform various operations with ease.
Table of Contents
- Features
- Installation
- Prerequisites
- Getting Started
- Usage
- Asynchronous Usage
- Examples
- Contributing
- License
Features
- Authenticate with the DX API using JWT tokens.
- Manage installations and datasets.
- Upload and download data to and from datasets.
- Synchronous and asynchronous support.
- Context managers for handling authentication scopes.
Installation
You can install the library using pip
:
pip install dx-api-client
Note: Replace dx-api-client
with the actual package name when it's published.
Prerequisites
- Python 3.10 or higher.
- An application ID (
app_id
) and a corresponding private key in PEM format. - DX API access credentials.
Getting Started
Authentication
The library uses JWT tokens for authentication. You need to provide your app_id
and the path to your private key file when initializing the client.
Initialization
from dx_api_client import DX
# Initialize the client
dx = DX(app_id='your_app_id', private_key_path='path/to/private_key.pem')
# OR
dx = DX(app_id='your_app_id', private_key='your_private_key')
Alternatively, you can set the environment variables DX_CONFIG_APP_ID
and DX_CONFIG_PRIVATE_KEY_PATH
:
export DX_CONFIG_APP_ID='your_app_id'
export DX_CONFIG_PRIVATE_KEY_PATH='path/to/private_key.pem'
# OR
export DX_CONFIG_PRIVATE_KEY='your_private_key'
And initialize the client without arguments:
dx = DX()
Usage
Who Am I
Retrieve information about the authenticated user:
user_info = dx.whoami()
print(user_info)
Managing Installations
Listing Installations
installations = dx.get_installations()
for installation in installations:
print(installation.name)
Accessing an Installation Context
Use the installation context to perform operations related to a specific installation:
# Find an installation by name or ID
installation = dx.installations.find(install_id=1)
# Use the installation context
with dx.installation(installation) as ctx:
# Perform operations within the context
datasets = list(ctx.datasets)
for dataset in datasets:
print(dataset.name)
Or enter context with a lookup by name:
with dx.installation(install_id=1) as ctx:
# Perform operations within the context
datasets = list(ctx.datasets)
for dataset in datasets:
print(dataset.name)
Managing Datasets
Listing Datasets
with dx.installation(installation) as ctx:
for dataset in ctx.datasets:
print(dataset.name)
Creating a Dataset
from dx_api_client import DatasetSchema, SchemaProperty
# Define the schema
schema = DatasetSchema(
properties=[
SchemaProperty(name='id', type='string', required=True),
SchemaProperty(name='value', type='number', required=True),
],
primary_key=['id']
)
# Create the dataset
with dx.installation(installation) as ctx:
new_dataset = ctx.datasets.create(
name='My Dataset',
description='A test dataset',
schema=schema.model_dump() # this can also be defined as a dictionary
)
Uploading Data to a Dataset
data = [
{'id': '1', 'value': 10},
{'id': '2', 'value': 20},
]
with dx.installation(installation) as ctx:
dataset_ops = ctx.datasets.find(name='My Dataset')
dataset_ops.load(data, validate_records=True) # validate_records=True will validate the records against the schema using Pydantic
Retrieving Records from a Dataset
with dx.installation(installation) as ctx:
dataset_ops = ctx.datasets.find(name='My Dataset')
records = dataset_ops.records()
for record in records:
print(record)
Asynchronous Usage
The library supports asynchronous operations using async
/await
.
import asyncio
async def main():
dx = DX()
async with dx.installation(installation) as ctx:
async for dataset in ctx.datasets:
print(dataset.name)
dataset = await ctx.datasets.find(name='My Dataset')
data = [
{'id': '1', 'value': 10},
{'id': '2', 'value': 20},
]
await dataset.load(data)
async for record in dataset.records():
print(record)
asyncio.run(main())
Examples
Example: Loading Data from a File
with dx.installation(installation) as ctx:
dataset = ctx.datasets.get(id='00000000-0000-0000-0000-000000000000')
dataset.load_from_file('data.csv')
Example: Uploading Data from a URL
with dx.installation(installation) as ctx:
dataset = ctx.datasets.find(name='My Dataset')
dataset.load_from_url('https://example.com/data.csv')
Note: This README assumes that the package name is dx-api-client
and that the code is properly packaged and available for installation via pip
. Adjust the instructions accordingly based on the actual package name and installation method.
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
Built Distribution
File details
Details for the file mig_dx_api-0.1.9.tar.gz
.
File metadata
- Download URL: mig_dx_api-0.1.9.tar.gz
- Upload date:
- Size: 55.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.12.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | b9a123db73a94e543fa82fe2a1b096ff21a3cbb0fc9d8652915857c27e3fe9be |
|
MD5 | 43102f0ab8aa40667f9dcc83652fa16b |
|
BLAKE2b-256 | f4ac5df32db39b2193703108eff9f6ee74b542e128843a2e073ea315b5616494 |
File details
Details for the file mig_dx_api-0.1.9-py3-none-any.whl
.
File metadata
- Download URL: mig_dx_api-0.1.9-py3-none-any.whl
- Upload date:
- Size: 12.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.12.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 704f866fc69d33a4c484dbc358c768d35e2a06d8c737f1666cb246a0de0d9579 |
|
MD5 | f501274f263068809d7b0215e149470c |
|
BLAKE2b-256 | 88394e8468ab1c1445785ffe07914874305696703167d3804cafbd8ea1764464 |