Python client for the Molgenis EMX2 API
Project description
README
The Molgenis EMX2 Pyclient is a Python package developed to be used for data management on Molgenis EMX2 servers. A detailed overview of the capabilities is presented in the MOLGENIS documentation.
Installation
The releases of the package are hosted at PyPI.
The recommended way to install the latest version is through pip.
pip install molgenis-emx2-pyclient
Changelog
Releases of the Molgenis EMX2 Pyclient follow the release number of the accompanying release of the Molgenis EMX2 software. Therefore, releases of the Pyclient are less frequent than those of EMX2 and the latest version of the Pyclient may differ from the latest version of Molgenis EMX2.
13.84.2
- Added: method
export_schemafor exporting a schema's metadata
13.77.1
- Improved error handling in 'columns' filter in
getmethod - Fixed asynchronous API calls in
export - Fixed issue with 'equals' filter for references in
getmethod - Fixed
greater_thanandsmaller_thanfilters for LONG type values ingetmethod - Renamed
__prepare_unequal_filtertoprepare_not_equals_filterand added NotImplementedError for certain data types - Fixed issue with incorrect column names in
get_graphql - Removed default value None for 'name' in
create_schemaas schema name cannot be null - Fixed parameter
include_demo_datainrecreate_schemato default toFalseinstead ofNone - Improved error handling when creating schema with non-existent template
13.75.1
- Fixed: issue when running
get_schema_metadataon a schema with insufficient permissions to see members - Added: methods
get_schema_settings - Added: methods
get_schema_members - Added: methods
get_schema_roles
13.55.4
Added: method save_table. Replaces save_schema which is now deprecated.
13.50.0
Fixed: issue with loading table data from get_graphql method
13.40.4
Fixed: no longer convert NA-like strings to pandas' NaN, only do this for missing values (i.e. empty strings).
11.61.2
Fixed: problem where the schema metadata could not be updated with upload_file and a molgenis.csv file.
11.57.0
- Added: feature 'truncate' to remove all entries from a table
- Added: option to filter results of
getmethod by columns - Added: method
get_graphqlimplements the GraphQL API - Improved: added additional parsing for data returned from the CSV API to pandas DataFrame in
getmethod - Fixed: log level was set to
DEBUGwithout possibility to change this. The user can now set the log level again at their preferred level
11.47.1
Fixed: updated GraphQL queries to be in line with EMX2 database metadata
11.23.0
Added: an optional job argument to the Client initialization,
allowing the Pyclient to run asynchronous methods within a job in EMX2."
11.11.1
Added: option to specify filename in method export and to return the exported data in a function
11.8.0
Breaking: introduced asynchronous methods. Users need to explicitly address the asynchronous methods
10.109.3
Added: the ability to use the Pyclient on an EMX2 instance running on a local machine.
10.98.0
Added: the option to filter the results obtained from the get method based on columns
10.92.1
Added: the method upload_file which allows the direct upload of files of multiple types to the API
10.72.1
Fixed: issue where NA values were not properly read in or returned by the API
10.48.9
Fixed: issue in managing data of a table where the table id differs from the table name
10.48.0
Added: option to save data from the get method as a pandas DataFrame
10.47.2
Fixed: exceptions for metadata classes Column and Schema
10.47.0
Added: metadata classes for Column, Table, Schema
10.13.1
Added: methods create_schema, delete_schema, update_schema, recreate_schema, get_schema_metadata
How to use
Within your Python project import the class Client and instantiate it as a context manager. Operations and queries can then be executed from within the context.
from molgenis_emx2_pyclient import Client
username = 'username'
password = '...'
with Client('https://example.molgeniscloud.org') as client:
client.signin(username, password)
# Retrieve signin information
print(client.status)
""" Output:
Host: https://example.molgeniscloud.org
Status: Signed in
Schemas:
CatalogueOntologies
catalogue
ExampleSchema
...
Version: v10.10.1
"""
# Retrieve data from a table on a schema
data = client.get(schema='ExampleSchema', table='Cohorts')
# Create a new schema on the server
client.create_schema(name='New Schema')
# Delete a schema from the server
client.delete_schema(name='New Schema')
Instead of signing in with a username and password the client can also be used while authorized by a (temporary) token that is generated on the server. See the MOLGENIS documentation for generating tokens
from molgenis_emx2_pyclient import Client
token = '...'
with Client('https://example.molgeniscloud.org', token=token) as client:
# Retrieve signin information
print(client.status)
""" Output:
Host: https://example.molgeniscloud.org
User: token
Status: session-less
Schemas:
CatalogueOntologies
catalogue
ExampleSchema
...
Version: v10.32.1
"""
...
...
Development
The Pyclient requires a Python installation with version 3.10 or higher.
Clone the molgenis-emx2 repository from GitHub
git clone git@github.com:molgenis/molgenis-emx2.git
Change the working directory to .../tools/pyclient
Create a virtual Python environment
On macOS:
python -m venv venv
On Linux:
python3.10 -m venv venv
On Windows:
py -3.10 venv venv
Activate the virtual environment
On macOS and Linux:
source venv/bin/activate
On Windows:
.venv\Scripts\activate.bat
Install the script dependencies
pip install -r requirements.txt
Build
Before building the source, the package build needs to be installed.
(venv) $ pip install build
(venv) $ python -m build
(venv) $ pip install dist/molgenis_emx2_pyclient*.whl
Test
Tests for the Pyclient have been created with the Pytest framework. In order to test the functionality of the Pyclient copy the '.env-example' file to '.env' and modify the parameters for the server you want to test on.
Then execute the following to run all the tests
(venv) molgenis-emx2/tools/pyclient$ pytest
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file molgenis_emx2_pyclient-13.84.2.tar.gz.
File metadata
- Download URL: molgenis_emx2_pyclient-13.84.2.tar.gz
- Upload date:
- Size: 30.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.11
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ea9429c4f1dd71790a3edd0e4151dbb98b257d4c024b7cf07f3ca6dd18bcf0ef
|
|
| MD5 |
bf985a2042976a0c1a0a405160ec4130
|
|
| BLAKE2b-256 |
5862a37ecff102fb8e73aa878d2cee16cb2f1302ececb1387da95b3ee6ddd80b
|
File details
Details for the file molgenis_emx2_pyclient-13.84.2-py3-none-any.whl.
File metadata
- Download URL: molgenis_emx2_pyclient-13.84.2-py3-none-any.whl
- Upload date:
- Size: 23.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.11
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
0419bc41dbcde717f2529f20f78027cd27f87aeb3e1b3e31046e946c7cd16325
|
|
| MD5 |
1b998ebe469cc34a6a8252e1915fe0e4
|
|
| BLAKE2b-256 |
0d58543237c64b5da8f1e63510da3a468b5b414252add86be583510bc0993b90
|