Skip to main content

Ranchero: metadata wrangling for bioinformatics

Project description

Ranchero

Is your mycobacterial metadata a mess? Grab the M. bovis by the horns with Ranchero.

Ranchero is a Python solution to the dozens of different metadata formats used in genomic datasets. While it is specifically focused on NCBI's collection of Mycobacterium tuberculosis complex metadata, it still has utility for other organisms.

GitHub: github.com/aofarrel/ranchero

Features

  • Pre-configured to standardize dozens of common NCBI metadata fields
  • Input a TSV/JSON/CSV of new samples and their metadata into a dataframe
  • Merge columns of similar data types into a single column, filling in nulls/empty values as you go
  • Input a TSV of metadata to "inject" into an existing dataframe, optionally overriding metadata already present
  • Flatten all of those "missing" and "Not Applicable" strings into proper null values
  • Convert countries into three-letter country codes per ISO 3166
  • Convert dates to YYYY-MM-DD format into an ISO 8601-like format
  • Convert common host animal names to the standardized Genus species format when possible, as well a common name
  • (tuberculosis only) Convert old-school strain names (Beijing, LAM, etc) to the modern lineage system (L2.2.1, L4.3, etc)

Dependencies

  • Python 3.11-ish (3.9+ should be okay)
  • pandas >= 2.0.0
  • pyarrow, even if not working with Apache Arrow datasets
  • polars for Python == 1.27.0
  • tqdm
  • xmltodict for working with Enterz Direct files

Supported inputs

Platform Expected format Ranchero function
BigQuery newline-delimited JSONL from_bigquery()
Enterz Direct (efetch) XML from_efetch()
NCBI SRA web search XML from_efetch()
Excel/LibreOffice TSV (XLSX not supported) from_tsv()
Google Sheets TSV from_tsv()
NCBI Run Selector CSV from_run_selector()
basically anything else TSV from_tsv()

BQ typically outputs JSONs in a format polars does not like; from_bigquery() will fix it on the fly.
efetch typically outputs an invalid XML; from_efetch() will fix it on the fly. However, note that only -db sra -format native -mode xml and output from NCBI SRA web search is supported.

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

ranchero-0.1.0rc25.tar.gz (111.0 kB view details)

Uploaded Source

Built Distribution

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

ranchero-0.1.0rc25-py3-none-any.whl (116.7 kB view details)

Uploaded Python 3

File details

Details for the file ranchero-0.1.0rc25.tar.gz.

File metadata

  • Download URL: ranchero-0.1.0rc25.tar.gz
  • Upload date:
  • Size: 111.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.3

File hashes

Hashes for ranchero-0.1.0rc25.tar.gz
Algorithm Hash digest
SHA256 bceeefb3eb91c981abd209be6724a776b9c85f98d2188bf471e136bee8e55b73
MD5 8bef9c4b0360fbff12861375aa6abf5c
BLAKE2b-256 4945ce4acd7c897f74a573b3c36f9409252a9bb64756c10ccba61d3f031568c2

See more details on using hashes here.

File details

Details for the file ranchero-0.1.0rc25-py3-none-any.whl.

File metadata

  • Download URL: ranchero-0.1.0rc25-py3-none-any.whl
  • Upload date:
  • Size: 116.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.3

File hashes

Hashes for ranchero-0.1.0rc25-py3-none-any.whl
Algorithm Hash digest
SHA256 66227dad9049861aa7e2ff5f9a5ce8404bfb7833555eb72ab4404449573707b3
MD5 cd4fef0f390916f47fa3561adf7da512
BLAKE2b-256 f1fd5f0d4ccc5aab38eea04c126b2ef5b004f7b64b8313fd0a20f04559d739c1

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