Skip to main content

Convert PubMed articles (PMIDs or PMCIDs) to clean, structured markdown with full text, abstracts, and supplementary materials

Project description

PubMed Downloader

PyPI

Convert PubMed articles to clean, structured markdown. Handles the full pipeline: PMID resolution, full-text extraction via PubMed Central, HTML-to-markdown conversion, and supplementary material retrieval.

Articles without open-access full text automatically fall back to abstract-only download.

Installation

pip install pubmed-markdown

Setup

Set your email for NCBI API identification (optional but recommended):

export NCBI_EMAIL=your-email@institution.edu

Or create a .env file in your working directory:

NCBI_EMAIL=your-email@institution.edu

Usage

Python API

Get markdown strings (single or batch, no files created):

from pubmed_markdown import PubMedMarkdown

downloader = PubMedMarkdown()

# From PMID — accepts a single string or a list
markdown = downloader.pmid_to_markdown("12895196")
markdowns = downloader.pmid_to_markdown(["12895196", "17872605"])

# From PMCID directly — also accepts a single string or a list
markdown = downloader.pmcid_to_markdown("PMC1884285")
markdowns = downloader.pmcid_to_markdown(["PMC1884285", "PMC6435416"])

Save markdown files to disk (single or batch):

from pubmed_markdown import PubMedMarkdown

downloader = PubMedMarkdown()
downloader.pmids_to_markdown_files(["12895196", "17872605"], save_dir="data")

# Also works with a single PMID
downloader.pmids_to_markdown_files("25051018", save_dir="data")

This creates:

data/
├── html/          # Raw HTML from PMC
└── markdown/      # Converted markdown files

Individual utility functions:

from pubmed_markdown import (
    get_pmcid_from_pmid,
    get_html_from_pmcid,
    get_abstract_markdown_from_pmid,
    fetch_bioc_supplement,
)

# Resolve PMIDs to PMCIDs
mapping = get_pmcid_from_pmid(["12895196", "17872605"])

# Fetch raw HTML from PMC
html = get_html_from_pmcid("PMC1884285")

# Get abstract for non-open-access articles
abstract_md = get_abstract_markdown_from_pmid("12345678")

# Get supplementary material text
supplement = fetch_bioc_supplement("PMC6435416")

Command Line

# Convert PMIDs from a file (one PMID per line)
pubmed-download --file_path=pmids.txt --save_dir=data

API Reference

Method Creates Files Returns Use Case
pmid_to_markdown() No Markdown string(s) Single or batch, programmatic use
pmcid_to_markdown() No Markdown string(s) Direct PMCID conversion
pmids_to_markdown_files() Yes None Batch processing, building datasets
local_html_to_markdown() Yes None Re-convert existing HTML files

All methods accepting IDs take either a single string or a list of strings.

How It Works

  1. PMID to PMCID -- Uses NCBI's ID Converter API with batching and rate limiting
  2. HTML extraction -- Fetches full article HTML from PubMed Central
  3. Markdown conversion -- Converts HTML to structured markdown preserving tables, figures, citations, and references
  4. Supplementary materials -- Fetches pre-processed supplement text via NCBI's BioC API
  5. Abstract fallback -- Articles not in PMC Open Access get abstract + metadata via NCBI E-Fetch

Configuration

Environment Variable Default Description
NCBI_EMAIL None Email for NCBI API identification

License

MIT

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

pubmed_markdown-0.2.1.tar.gz (53.2 kB view details)

Uploaded Source

Built Distribution

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

pubmed_markdown-0.2.1-py3-none-any.whl (21.5 kB view details)

Uploaded Python 3

File details

Details for the file pubmed_markdown-0.2.1.tar.gz.

File metadata

  • Download URL: pubmed_markdown-0.2.1.tar.gz
  • Upload date:
  • Size: 53.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.2

File hashes

Hashes for pubmed_markdown-0.2.1.tar.gz
Algorithm Hash digest
SHA256 fb8e35364aea03b9637f810758e8075ca780e24879475268b6721f29d2a78545
MD5 3ee83c1900986b36231cbaa40fe5f8b8
BLAKE2b-256 db77b0a8ddfe59462c6ad12ce02a9983f8ab8a8234e7e181661a41714911acb8

See more details on using hashes here.

File details

Details for the file pubmed_markdown-0.2.1-py3-none-any.whl.

File metadata

File hashes

Hashes for pubmed_markdown-0.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 a6bb51b2b099c914542239e83cce34a2b5ca68efc6b494bd2f7d9ec3eb863d83
MD5 07f1070efd972fe9d6a86ccf7511dd61
BLAKE2b-256 b2e24af290e4b9101d8f0e0625109c8ff83819775acf12ebc1d2c99622acce01

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