Skip to main content

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_schema for exporting a schema's metadata

13.77.1

  • Improved error handling in 'columns' filter in get method
  • Fixed asynchronous API calls in export
  • Fixed issue with 'equals' filter for references in get method
  • Fixed greater_than and smaller_than filters for LONG type values in get method
  • Renamed __prepare_unequal_filter to prepare_not_equals_filter and added NotImplementedError for certain data types
  • Fixed issue with incorrect column names in get_graphql
  • Removed default value None for 'name' in create_schema as schema name cannot be null
  • Fixed parameter include_demo_data in recreate_schema to default to False instead of None
  • Improved error handling when creating schema with non-existent template

13.75.1

  • Fixed: issue when running get_schema_metadata on 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 get method by columns
  • Added: method get_graphql implements the GraphQL API
  • Improved: added additional parsing for data returned from the CSV API to pandas DataFrame in get method
  • Fixed: log level was set to DEBUG without 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

molgenis_emx2_pyclient-13.84.2.tar.gz (30.7 kB view details)

Uploaded Source

Built Distribution

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

molgenis_emx2_pyclient-13.84.2-py3-none-any.whl (23.4 kB view details)

Uploaded Python 3

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

Hashes for molgenis_emx2_pyclient-13.84.2.tar.gz
Algorithm Hash digest
SHA256 ea9429c4f1dd71790a3edd0e4151dbb98b257d4c024b7cf07f3ca6dd18bcf0ef
MD5 bf985a2042976a0c1a0a405160ec4130
BLAKE2b-256 5862a37ecff102fb8e73aa878d2cee16cb2f1302ececb1387da95b3ee6ddd80b

See more details on using hashes here.

File details

Details for the file molgenis_emx2_pyclient-13.84.2-py3-none-any.whl.

File metadata

File hashes

Hashes for molgenis_emx2_pyclient-13.84.2-py3-none-any.whl
Algorithm Hash digest
SHA256 0419bc41dbcde717f2529f20f78027cd27f87aeb3e1b3e31046e946c7cd16325
MD5 1b998ebe469cc34a6a8252e1915fe0e4
BLAKE2b-256 0d58543237c64b5da8f1e63510da3a468b5b414252add86be583510bc0993b90

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