Skip to main content

A Python client for interacting with the ClinicalTrials.gov API v2

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.9.tar.gz (5.0 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.9-py3-none-any.whl (6.2 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: pyctrials-0.1.9.tar.gz
  • Upload date:
  • Size: 5.0 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.9.tar.gz
Algorithm Hash digest
SHA256 9184eb13008b822bf2298f6122fb82c4506a7d4fb9a96b6f2dc5ef4a1bdeb697
MD5 9c4da24b69183111bddcbc7a97d306cb
BLAKE2b-256 e66c3ea0622496451133fb815253412e059be15c31135a5c48400c23253317b1

See more details on using hashes here.

File details

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

File metadata

  • Download URL: pyctrials-0.1.9-py3-none-any.whl
  • Upload date:
  • Size: 6.2 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.9-py3-none-any.whl
Algorithm Hash digest
SHA256 694c0a60ebb74aa05e3b7f10341c61a569d0393f5fe033d3c4c4a4642daac275
MD5 d8fe4da8848b95dfa678599d004a0964
BLAKE2b-256 78b58b4f4aa2155a93f200dd28040e33bd78214c72b6930f0f3dd24e40586184

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