# MedlinePlus Scraper (`crawlerbros/medlineplus-scraper`) Actor

Scrape MedlinePlus, NIH's free consumer health information service. Search health topics by keyword, look up by ICD-10 code, RxCUI drug code, or LOINC lab code. Trusted source from the National Library of Medicine.

- **URL**: https://apify.com/crawlerbros/medlineplus-scraper.md
- **Developed by:** [Crawler Bros](https://apify.com/crawlerbros) (community)
- **Categories:** AI, Developer tools, Automation
- **Stats:** 2 total users, 1 monthly users, 100.0% runs succeeded, NaN bookmarks
- **User rating**: No ratings yet

## Pricing

from $3.00 / 1,000 results

This Actor is paid per event and usage. You are charged both the fixed price for specific events and for Apify platform usage.
Since this Actor supports Apify Store discounts, the price gets lower the higher subscription plan you have.

Learn more: https://docs.apify.com/platform/actors/running/actors-in-store#pay-per-event

## What's an Apify Actor?

Actors are a software tools running on the Apify platform, for all kinds of web data extraction and automation use cases.
In Batch mode, an Actor accepts a well-defined JSON input, performs an action which can take anything from a few seconds to a few hours,
and optionally produces a well-defined JSON output, datasets with results, or files in key-value store.
In Standby mode, an Actor provides a web server which can be used as a website, API, or an MCP server.
Actors are written with capital "A".

## How to integrate an Actor?

If asked about integration, you help developers integrate Actors into their projects.
You adapt to their stack and deliver integrations that are safe, well-documented, and production-ready.
The best way to integrate Actors is as follows.

In JavaScript/TypeScript projects, use official [JavaScript/TypeScript client](https://docs.apify.com/api/client/js.md):

```bash
npm install apify-client
```

In Python projects, use official [Python client library](https://docs.apify.com/api/client/python.md):

```bash
pip install apify-client
```

In shell scripts, use [Apify CLI](https://docs.apify.com/cli/docs.md):

````bash
# MacOS / Linux
curl -fsSL https://apify.com/install-cli.sh | bash
# Windows
irm https://apify.com/install-cli.ps1 | iex
```bash

In AI frameworks, you might use the [Apify MCP server](https://docs.apify.com/platform/integrations/mcp.md).

If your project is in a different language, use the [REST API](https://docs.apify.com/api/v2.md).

For usage examples, see the [API](#api) section below.

For more details, see Apify documentation as [Markdown index](https://docs.apify.com/llms.txt) and [Markdown full-text](https://docs.apify.com/llms-full.txt).


# README

## MedlinePlus Scraper

Scrape **MedlinePlus** — the U.S. National Library of Medicine's free consumer health information service trusted by millions. Search health topics by keyword or look up authoritative medical information by clinical code (ICD-10, RxNorm, LOINC).

### What you get

- **Health topic articles** — titles, summaries, synonyms, MeSH terms, and topic categories from the NLM health topics database
- **Clinical code lookups** — structured health information for ICD-10 diagnosis codes, RxNorm drug identifiers, and LOINC lab test codes via the MedlinePlus Connect service
- **Bilingual support** — retrieve results in English or Spanish
- **No API key required** — MedlinePlus is a public U.S. government service

### Data source

All data is sourced from **MedlinePlus** (medlineplus.gov), produced by the [U.S. National Library of Medicine](https://www.nlm.nih.gov), a division of the National Institutes of Health (NIH). Data is provided under U.S. government open data terms.

### Use cases

- Clinical decision support and patient education materials
- Building health information portals and apps
- Drug reference and medication research
- Lab test information retrieval
- Medical coding verification and education
- Health topic research and content aggregation

### Modes

| Mode | Description | Required input |
|---|---|---|
| `search` | Search health topics by keyword | `query` |
| `byICD10Code` | Look up health info for an ICD-10-CM diagnosis code | `icdCode` |
| `byRxCUI` | Look up drug information by RxNorm Concept Unique Identifier | `rxcui` |
| `byLOINC` | Look up lab test information by LOINC code | `loincCode` |

### Input

| Field | Type | Description | Example |
|---|---|---|---|
| `mode` | select | Which data source to query | `search` |
| `query` | string | Keyword to search (mode=search) | `diabetes` |
| `language` | select | Language for results: `en` (English) or `es` (Spanish) | `en` |
| `icdCode` | string | ICD-10-CM diagnosis code (mode=byICD10Code) | `I10` |
| `rxcui` | string | RxNorm CUI for a drug (mode=byRxCUI) | `161` |
| `loincCode` | string | LOINC code for a lab test (mode=byLOINC) | `2345-7` |
| `maxItems` | integer | Maximum records to return (1–500) | `20` |

#### ICD-10 code examples

| Code | Condition |
|---|---|
| `I10` | Essential (primary) hypertension |
| `E11` | Type 2 diabetes mellitus |
| `J45` | Asthma |
| `F32` | Major depressive disorder |
| `M79` | Soft tissue disorders |

#### RxNorm CUI examples

| RXCUI | Drug |
|---|---|
| `161` | Acetaminophen |
| `1049502` | Oxycodone |
| `7847` | Ibuprofen |

#### LOINC code examples

| Code | Test |
|---|---|
| `2345-7` | Blood glucose |
| `718-7` | Hemoglobin |
| `4548-4` | Hemoglobin A1c |
| `2160-0` | Creatinine |

### Output

Each record contains:

| Field | Description |
|---|---|
| `title` | Health topic or drug/test name |
| `url` | Direct link to the MedlinePlus page |
| `snippet` | Summary paragraph (plain text, HTML stripped) |
| `fullSummary` | Extended summary (search mode, up to 800 chars) |
| `synonyms` | Alternative names and related terms |
| `categories` | Topic categories (e.g. "Endocrine System") |
| `meshTerms` | Medical Subject Headings |
| `code` | Medical code queried (code-based modes) |
| `codeSystem` | Code system name (ICD-10-CM, RxNorm, LOINC) |
| `language` | Language of the result |
| `lastUpdated` | Last update timestamp (code-based modes) |
| `source` | Always "MedlinePlus" |
| `scrapedAt` | ISO 8601 timestamp when the record was scraped |

### FAQs

**Is an API key required?**
No. MedlinePlus is a free public service. No registration, API key, or authentication is needed.

**How current is the data?**
MedlinePlus content is maintained and updated by the National Library of Medicine. The scraper retrieves the latest published content on each run.

**Can I search in Spanish?**
Yes. Set `language` to `es` to retrieve Spanish-language health topic results. Both keyword search and code-based lookups support Spanish via the MedlinePlus Connect service.

**What is MedlinePlus Connect?**
MedlinePlus Connect is an NLM web service that links clinical systems (EHRs) to relevant MedlinePlus health information using standard medical codes (ICD-10-CM, RxNorm, LOINC).

**How many results does a code lookup return?**
Typically 1–5 results per code, covering the most relevant health topic pages for that condition or drug.

**What is the daily test run prefill?**
The default prefill `{"mode": "search", "query": "diabetes", "maxItems": 5}` consistently returns results and is used for daily automated testing.

# Actor input Schema

## `mode` (type: `string`):

Which MedlinePlus data source to query.
## `query` (type: `string`):

Free-text keyword to search MedlinePlus health topics (e.g. `diabetes`, `heart disease`).
## `language` (type: `string`):

Language for search results and topic content.
## `icdCode` (type: `string`):

ICD-10-CM diagnosis code (e.g. `I10` for hypertension, `E11` for type 2 diabetes, `J45` for asthma).
## `rxcui` (type: `string`):

RxNorm Concept Unique Identifier (e.g. `161` for acetaminophen, `1049502` for oxycodone).
## `loincCode` (type: `string`):

LOINC lab test code (e.g. `2345-7` for glucose, `718-7` for hemoglobin).
## `maxItems` (type: `integer`):

Maximum number of records to emit.

## Actor input object example

```json
{
  "mode": "search",
  "query": "diabetes",
  "language": "en",
  "maxItems": 5
}
````

# Actor output Schema

## `healthTopics` (type: `string`):

Dataset containing all scraped MedlinePlus health topic records.

# API

You can run this Actor programmatically using our API. Below are code examples in JavaScript, Python, and CLI, as well as the OpenAPI specification and MCP server setup.

## JavaScript example

```javascript
import { ApifyClient } from 'apify-client';

// Initialize the ApifyClient with your Apify API token
// Replace the '<YOUR_API_TOKEN>' with your token
const client = new ApifyClient({
    token: '<YOUR_API_TOKEN>',
});

// Prepare Actor input
const input = {
    "mode": "search",
    "query": "diabetes",
    "language": "en",
    "maxItems": 5
};

// Run the Actor and wait for it to finish
const run = await client.actor("crawlerbros/medlineplus-scraper").call(input);

// Fetch and print Actor results from the run's dataset (if any)
console.log('Results from dataset');
console.log(`💾 Check your data here: https://console.apify.com/storage/datasets/${run.defaultDatasetId}`);
const { items } = await client.dataset(run.defaultDatasetId).listItems();
items.forEach((item) => {
    console.dir(item);
});

// 📚 Want to learn more 📖? Go to → https://docs.apify.com/api/client/js/docs

```

## Python example

```python
from apify_client import ApifyClient

# Initialize the ApifyClient with your Apify API token
# Replace '<YOUR_API_TOKEN>' with your token.
client = ApifyClient("<YOUR_API_TOKEN>")

# Prepare the Actor input
run_input = {
    "mode": "search",
    "query": "diabetes",
    "language": "en",
    "maxItems": 5,
}

# Run the Actor and wait for it to finish
run = client.actor("crawlerbros/medlineplus-scraper").call(run_input=run_input)

# Fetch and print Actor results from the run's dataset (if there are any)
print("💾 Check your data here: https://console.apify.com/storage/datasets/" + run["defaultDatasetId"])
for item in client.dataset(run["defaultDatasetId"]).iterate_items():
    print(item)

# 📚 Want to learn more 📖? Go to → https://docs.apify.com/api/client/python/docs/quick-start

```

## CLI example

```bash
echo '{
  "mode": "search",
  "query": "diabetes",
  "language": "en",
  "maxItems": 5
}' |
apify call crawlerbros/medlineplus-scraper --silent --output-dataset

```

## MCP server setup

```json
{
    "mcpServers": {
        "apify": {
            "command": "npx",
            "args": [
                "mcp-remote",
                "https://mcp.apify.com/?tools=crawlerbros/medlineplus-scraper",
                "--header",
                "Authorization: Bearer <YOUR_API_TOKEN>"
            ]
        }
    }
}

```

## OpenAPI specification

```json
{
    "openapi": "3.0.1",
    "info": {
        "title": "MedlinePlus Scraper",
        "description": "Scrape MedlinePlus, NIH's free consumer health information service. Search health topics by keyword, look up by ICD-10 code, RxCUI drug code, or LOINC lab code. Trusted source from the National Library of Medicine.",
        "version": "1.0",
        "x-build-id": "ypDmbmnRkeEhiA3T9"
    },
    "servers": [
        {
            "url": "https://api.apify.com/v2"
        }
    ],
    "paths": {
        "/acts/crawlerbros~medlineplus-scraper/run-sync-get-dataset-items": {
            "post": {
                "operationId": "run-sync-get-dataset-items-crawlerbros-medlineplus-scraper",
                "x-openai-isConsequential": false,
                "summary": "Executes an Actor, waits for its completion, and returns Actor's dataset items in response.",
                "tags": [
                    "Run Actor"
                ],
                "requestBody": {
                    "required": true,
                    "content": {
                        "application/json": {
                            "schema": {
                                "$ref": "#/components/schemas/inputSchema"
                            }
                        }
                    }
                },
                "parameters": [
                    {
                        "name": "token",
                        "in": "query",
                        "required": true,
                        "schema": {
                            "type": "string"
                        },
                        "description": "Enter your Apify token here"
                    }
                ],
                "responses": {
                    "200": {
                        "description": "OK"
                    }
                }
            }
        },
        "/acts/crawlerbros~medlineplus-scraper/runs": {
            "post": {
                "operationId": "runs-sync-crawlerbros-medlineplus-scraper",
                "x-openai-isConsequential": false,
                "summary": "Executes an Actor and returns information about the initiated run in response.",
                "tags": [
                    "Run Actor"
                ],
                "requestBody": {
                    "required": true,
                    "content": {
                        "application/json": {
                            "schema": {
                                "$ref": "#/components/schemas/inputSchema"
                            }
                        }
                    }
                },
                "parameters": [
                    {
                        "name": "token",
                        "in": "query",
                        "required": true,
                        "schema": {
                            "type": "string"
                        },
                        "description": "Enter your Apify token here"
                    }
                ],
                "responses": {
                    "200": {
                        "description": "OK",
                        "content": {
                            "application/json": {
                                "schema": {
                                    "$ref": "#/components/schemas/runsResponseSchema"
                                }
                            }
                        }
                    }
                }
            }
        },
        "/acts/crawlerbros~medlineplus-scraper/run-sync": {
            "post": {
                "operationId": "run-sync-crawlerbros-medlineplus-scraper",
                "x-openai-isConsequential": false,
                "summary": "Executes an Actor, waits for completion, and returns the OUTPUT from Key-value store in response.",
                "tags": [
                    "Run Actor"
                ],
                "requestBody": {
                    "required": true,
                    "content": {
                        "application/json": {
                            "schema": {
                                "$ref": "#/components/schemas/inputSchema"
                            }
                        }
                    }
                },
                "parameters": [
                    {
                        "name": "token",
                        "in": "query",
                        "required": true,
                        "schema": {
                            "type": "string"
                        },
                        "description": "Enter your Apify token here"
                    }
                ],
                "responses": {
                    "200": {
                        "description": "OK"
                    }
                }
            }
        }
    },
    "components": {
        "schemas": {
            "inputSchema": {
                "type": "object",
                "required": [
                    "mode"
                ],
                "properties": {
                    "mode": {
                        "title": "Mode",
                        "enum": [
                            "search",
                            "byICD10Code",
                            "byRxCUI",
                            "byLOINC"
                        ],
                        "type": "string",
                        "description": "Which MedlinePlus data source to query.",
                        "default": "search"
                    },
                    "query": {
                        "title": "Search query (mode=search)",
                        "type": "string",
                        "description": "Free-text keyword to search MedlinePlus health topics (e.g. `diabetes`, `heart disease`).",
                        "default": "diabetes"
                    },
                    "language": {
                        "title": "Language",
                        "enum": [
                            "en",
                            "es"
                        ],
                        "type": "string",
                        "description": "Language for search results and topic content.",
                        "default": "en"
                    },
                    "icdCode": {
                        "title": "ICD-10-CM code (mode=byICD10Code)",
                        "type": "string",
                        "description": "ICD-10-CM diagnosis code (e.g. `I10` for hypertension, `E11` for type 2 diabetes, `J45` for asthma)."
                    },
                    "rxcui": {
                        "title": "RxNorm CUI (mode=byRxCUI)",
                        "type": "string",
                        "description": "RxNorm Concept Unique Identifier (e.g. `161` for acetaminophen, `1049502` for oxycodone)."
                    },
                    "loincCode": {
                        "title": "LOINC code (mode=byLOINC)",
                        "type": "string",
                        "description": "LOINC lab test code (e.g. `2345-7` for glucose, `718-7` for hemoglobin)."
                    },
                    "maxItems": {
                        "title": "Max items",
                        "minimum": 1,
                        "maximum": 500,
                        "type": "integer",
                        "description": "Maximum number of records to emit.",
                        "default": 20
                    }
                }
            },
            "runsResponseSchema": {
                "type": "object",
                "properties": {
                    "data": {
                        "type": "object",
                        "properties": {
                            "id": {
                                "type": "string"
                            },
                            "actId": {
                                "type": "string"
                            },
                            "userId": {
                                "type": "string"
                            },
                            "startedAt": {
                                "type": "string",
                                "format": "date-time",
                                "example": "2025-01-08T00:00:00.000Z"
                            },
                            "finishedAt": {
                                "type": "string",
                                "format": "date-time",
                                "example": "2025-01-08T00:00:00.000Z"
                            },
                            "status": {
                                "type": "string",
                                "example": "READY"
                            },
                            "meta": {
                                "type": "object",
                                "properties": {
                                    "origin": {
                                        "type": "string",
                                        "example": "API"
                                    },
                                    "userAgent": {
                                        "type": "string"
                                    }
                                }
                            },
                            "stats": {
                                "type": "object",
                                "properties": {
                                    "inputBodyLen": {
                                        "type": "integer",
                                        "example": 2000
                                    },
                                    "rebootCount": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "restartCount": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "resurrectCount": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "computeUnits": {
                                        "type": "integer",
                                        "example": 0
                                    }
                                }
                            },
                            "options": {
                                "type": "object",
                                "properties": {
                                    "build": {
                                        "type": "string",
                                        "example": "latest"
                                    },
                                    "timeoutSecs": {
                                        "type": "integer",
                                        "example": 300
                                    },
                                    "memoryMbytes": {
                                        "type": "integer",
                                        "example": 1024
                                    },
                                    "diskMbytes": {
                                        "type": "integer",
                                        "example": 2048
                                    }
                                }
                            },
                            "buildId": {
                                "type": "string"
                            },
                            "defaultKeyValueStoreId": {
                                "type": "string"
                            },
                            "defaultDatasetId": {
                                "type": "string"
                            },
                            "defaultRequestQueueId": {
                                "type": "string"
                            },
                            "buildNumber": {
                                "type": "string",
                                "example": "1.0.0"
                            },
                            "containerUrl": {
                                "type": "string"
                            },
                            "usage": {
                                "type": "object",
                                "properties": {
                                    "ACTOR_COMPUTE_UNITS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATASET_READS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATASET_WRITES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "KEY_VALUE_STORE_READS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "KEY_VALUE_STORE_WRITES": {
                                        "type": "integer",
                                        "example": 1
                                    },
                                    "KEY_VALUE_STORE_LISTS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "REQUEST_QUEUE_READS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "REQUEST_QUEUE_WRITES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATA_TRANSFER_INTERNAL_GBYTES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATA_TRANSFER_EXTERNAL_GBYTES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "PROXY_RESIDENTIAL_TRANSFER_GBYTES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "PROXY_SERPS": {
                                        "type": "integer",
                                        "example": 0
                                    }
                                }
                            },
                            "usageTotalUsd": {
                                "type": "number",
                                "example": 0.00005
                            },
                            "usageUsd": {
                                "type": "object",
                                "properties": {
                                    "ACTOR_COMPUTE_UNITS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATASET_READS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATASET_WRITES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "KEY_VALUE_STORE_READS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "KEY_VALUE_STORE_WRITES": {
                                        "type": "number",
                                        "example": 0.00005
                                    },
                                    "KEY_VALUE_STORE_LISTS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "REQUEST_QUEUE_READS": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "REQUEST_QUEUE_WRITES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATA_TRANSFER_INTERNAL_GBYTES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "DATA_TRANSFER_EXTERNAL_GBYTES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "PROXY_RESIDENTIAL_TRANSFER_GBYTES": {
                                        "type": "integer",
                                        "example": 0
                                    },
                                    "PROXY_SERPS": {
                                        "type": "integer",
                                        "example": 0
                                    }
                                }
                            }
                        }
                    }
                }
            }
        }
    }
}
```
