Skip to main content

A Python client for the ClinicalTrials.gov API

Project description

Clinical Trials API Client

A Python client for interacting with the ClinicalTrials.gov API v2. This library provides an easy-to-use interface for fetching and analyzing clinical trial data.

Installation

You can install the package via pip:

pip install pyctrials

Quick Start

from clinical_trials_api import ClinicalTrialsAPI

# Initialize the client
client = ClinicalTrialsAPI()

# Fetch trials for a specific condition
trials = client.fetch_trials("Pompe Disease")

# Display results
print(f"Found {len(trials)} trials")
print(trials[['nct_id', 'brief_title', 'overall_status']].head())

Features

  • Easy-to-use interface for ClinicalTrials.gov API
  • Automatic pagination handling
  • Retry mechanism for failed requests
  • Data parsing and cleanup
  • DataFrame-based output for easy analysis
  • Comprehensive trial information including:
    • Trial identification
    • Status information
    • Sponsor details
    • Study design
    • Location information
    • And more...

Documentation

ClinicalTrialsAPI

The main class for interacting with the API.

client = ClinicalTrialsAPI(max_retries=5, retry_delay=5)

Parameters:

  • max_retries (int): Maximum number of retry attempts for failed requests
  • retry_delay (int): Delay between retry attempts in seconds

Methods

fetch_trials()

trials = client.fetch_trials(
    condition="Pompe Disease",
    status="RECRUITING",
    page_size=10
)

Parameters: other parameters will follow

  • condition (str): Medical condition to search for
  • status (str): Trial status filter (default: 'RECRUITING') (ACTIVE_NOT_RECRUITING ┃ COMPLETED ┃ ENROLLING_BY_INVITATION ┃ NOT_YET_RECRUITING ┃ RECRUITING ┃ SUSPENDED ┃ TERMINATED ┃ WITHDRAWN ┃ AVAILABLE ┃ NO_LONGER_AVAILABLE ┃ TEMPORARILY_NOT_AVAILABLE ┃ APPROVED_FOR_MARKETING ┃ WITHHELD ┃ UNKNOWN) --> visit https://clinicaltrials.gov/data-api/api#get-/studies for more info
  • page_size (int): Number of results per page (default: 10)

Returns:

  • pandas.DataFrame containing the trial data

Examples

Basic Usage

from clinical_trials_api import ClinicalTrialsAPI

# Initialize client
client = ClinicalTrialsAPI()

# Fetch trials
trials = client.fetch_trials("Spinal Muscular Atrophy")

# Show unique sponsors
print(trials['sponsor'].unique())

# Get trials by phase
phase_counts = trials['phase'].value_counts()
print(phase_counts)

Error Handling

try:
    trials = client.fetch_trials("Rare Disease")
except Exception as e:
    print(f"An error occurred: {e}")

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

License

This project is licensed under the MIT License - see the LICENSE file for details.

Acknowledgments

  • Thanks to ClinicalTrials.gov for providing the API
  • Built with Python, pandas, and requests

Citation

If you use this package in your research, please cite:

@software{pyctrials,
  author = {Anass Tinakoua},
  title = {Clinical Trials API Client},
  year = {2024},
  publisher = {GitHub},
  url = {https://github.com/atinak/pyctrials}
}

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

pyctrials-0.1.8.tar.gz (3.6 kB view details)

Uploaded Source

Built Distribution

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

pyctrials-0.1.8-py3-none-any.whl (3.5 kB view details)

Uploaded Python 3

File details

Details for the file pyctrials-0.1.8.tar.gz.

File metadata

  • Download URL: pyctrials-0.1.8.tar.gz
  • Upload date:
  • Size: 3.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.9.21

File hashes

Hashes for pyctrials-0.1.8.tar.gz
Algorithm Hash digest
SHA256 5c56037e9976399d058ff9174b0adaed9ec6e99bf82613a31eacf7af82b68617
MD5 789855670889645585f7d5f30fea93f5
BLAKE2b-256 f59fc48091ec8fa0e0098269d403a85fdd762eecb0a561cc5beba297d1fb1828

See more details on using hashes here.

File details

Details for the file pyctrials-0.1.8-py3-none-any.whl.

File metadata

  • Download URL: pyctrials-0.1.8-py3-none-any.whl
  • Upload date:
  • Size: 3.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.9.21

File hashes

Hashes for pyctrials-0.1.8-py3-none-any.whl
Algorithm Hash digest
SHA256 764abbd661e89d5ca349a693bd43a3717947e5a9d696efbffddc4707509e2cb5
MD5 8ba5e3d84bbd3d2069c5f8b3b28972a1
BLAKE2b-256 2cfe57828e7c0b5ccb388228b8d7b16e1742eb6afcdfe45792f511643b5825ce

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