Skip to main content

Library of Python utilities that I needed so many times

Project description

ddgen

Library of Python utilities that I needed so many times in the past

Select RefSeq transcript with the highest priority

RefSeq transcripts have following categories:

  • NM_, XM_, NR_, XR_

If we have transcripts from multiple sources, we want to select the one coming from the source with highest priority.

E.g. NM_ has higher priority than XM_.

If we have multiple transcripts from a single source, we want to select the one with smaller integer.

E.g. NM_123.4 has higher priority than NM_124.4.

from ddgen.utils import _txs

# tx will be `NM_123.4`
tx = _txs.prioritize_refseq_transcripts(['NM_123.4', 'NM_124.4', 'XM_100.1'])

Get priority for Jannovar variant effects

Jannovar assigns one or more effects to a variant. The effects look like

  • MISSENSE_VARIANT,
  • STOP_GAINED,
  • SPLICE_DONOR_VARIANT,
  • CODING_TRANSCRIPT_VARIANT, etc.

The effects are sorted in order of decreasing putative pathogenicity (i.e. CODING_TRANSCRIPT_VARIANT is likely to be less deleterious than STOP_GAINED in general).

If the variant affects multiple transcripts, it can have different effects on each of them. In some situations, it might be useful to select and evaluate only the most serious effect.

In order to make the selection, we work with concept of variant effect priority. The lower the number representing the priority, the higher the priority.

We can do it by comparing effect priorities:

from ddgen.utils import get_variant_effect_priority, VARIANT_EFFECT_PRIORITIES

# `p` is 21 
p = get_variant_effect_priority('MISSENSE_VARIANT')

# `u` is -1
u = get_variant_effect_priority('GIBBERISH')

# `p` is 21 again
p = VARIANT_EFFECT_PRIORITIES['MISSENSE_VARIANT']

Connect to H2 database

The H2 database is a pure Java SQL database, hence it is primarily meant to be used with Java. We can connect to the database from Python, if:

  • Java is installed on the local machine
  • the local machine runs UNIX-like OS (sorry, Windows users)

In that case:

from ddgen.db import H2DbManager

with H2DbManager("path/to/database.mv.db", 
                 user="sa", 
                 password="sa") as h2:
    with h2.get_connection() as conn:
        with conn.cursor() as cur:
            # do whatever you want
            cur.execute('SELECT * FROM DB.TABLE;')
            for i, x in zip(range(5), cur.fetchall()):
                # print first 5 lines 
                print(x)

Setup logging

Quick setup of Python built-in logging library:

from ddgen.utils import setup_logging
setup_logging()

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

ddgen-0.0.7.tar.gz (4.3 MB view details)

Uploaded Source

Built Distributions

ddgen-0.0.7-py3.6.egg (4.3 MB view details)

Uploaded Source

ddgen-0.0.7-py3-none-any.whl (4.3 MB view details)

Uploaded Python 3

File details

Details for the file ddgen-0.0.7.tar.gz.

File metadata

  • Download URL: ddgen-0.0.7.tar.gz
  • Upload date:
  • Size: 4.3 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.23.0 setuptools/46.0.0.post20200309 requests-toolbelt/0.9.1 tqdm/4.43.0 CPython/3.7.3

File hashes

Hashes for ddgen-0.0.7.tar.gz
Algorithm Hash digest
SHA256 385a39125df909352b94a7a6fd9af4ffc35c547d824268d2ef8071c91426218e
MD5 1c94c87feafaa7a07da3a5699a94dba2
BLAKE2b-256 72508ee1a6890d5fc844c30241e5bb5063fcfe0c80379240f7df70030f355c64

See more details on using hashes here.

File details

Details for the file ddgen-0.0.7-py3.6.egg.

File metadata

  • Download URL: ddgen-0.0.7-py3.6.egg
  • Upload date:
  • Size: 4.3 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.23.0 setuptools/46.0.0.post20200309 requests-toolbelt/0.9.1 tqdm/4.43.0 CPython/3.7.3

File hashes

Hashes for ddgen-0.0.7-py3.6.egg
Algorithm Hash digest
SHA256 3d2408b2eb4bf5d76e9a2e47f37887ae9bf7da3ab1487469fa849544b3643692
MD5 6a5daf2319554836646c85d051ed83fa
BLAKE2b-256 8f1b2ed8bf4db6c4813bb64e7834413476391c17592aab284daed6efe03e3698

See more details on using hashes here.

File details

Details for the file ddgen-0.0.7-py3-none-any.whl.

File metadata

  • Download URL: ddgen-0.0.7-py3-none-any.whl
  • Upload date:
  • Size: 4.3 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.23.0 setuptools/46.0.0.post20200309 requests-toolbelt/0.9.1 tqdm/4.43.0 CPython/3.7.3

File hashes

Hashes for ddgen-0.0.7-py3-none-any.whl
Algorithm Hash digest
SHA256 c2fdaa6f99a9af0b60e70ef4ca0aed6f5bf8ab555b6e03b7667ac8d08305e464
MD5 cfeb792491d6e2d76e01d73b981d99d7
BLAKE2b-256 d2e72971745f50713feab6576f15ba1d836b6ea59f951c112e1a91a6755eb220

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