# CMS Nursing Home Compare Scraper (`crawlerbros/cms-nursing-home-compare-scraper`) Actor

Scrape CMS Nursing Home Compare data via the free data.cms.gov public API. Search nursing homes by state, get star ratings, inspection results, staffing info, and ownership data for all US nursing facilities. No API key required.

- **URL**: https://apify.com/crawlerbros/cms-nursing-home-compare-scraper.md
- **Developed by:** [Crawler Bros](https://apify.com/crawlerbros) (community)
- **Categories:** Automation, Developer tools
- **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

## CMS Nursing Home Compare Scraper

Scrape US nursing home and long-term care facility data from the **CMS Nursing Home Compare** program via the free [data.cms.gov](https://data.cms.gov) public API. No login, API key, or proxy required.

### What data does it collect?

Every CMS-certified nursing home in the United States, including:

- Facility name, address, city, state, ZIP code, county
- Phone number
- Ownership type (For-profit, Non-profit, Government)
- Overall star rating (1–5 stars) and sub-ratings (health inspections, staffing, quality measures)
- Number of certified beds and average daily residents
- Special Focus Facility (SFF) designation
- Abuse icon flag

### Modes

| Mode | Description |
|---|---|
| `searchFacilities` | Search by name/city keyword, optionally filtered by state |
| `facilityRatings` | Fetch facilities with star rating filtering |
| `facilityInspections` | Fetch facilities with inspection-related data |
| `searchByState` | All nursing homes in a specific US state |

### Input

```json
{
  "mode": "searchFacilities",
  "state": "FL",
  "searchQuery": "Sunrise",
  "ownershipType": "For profit - Corporation",
  "minRating": 3,
  "specialFocusOnly": false,
  "maxItems": 20
}
````

#### Input fields

| Field | Type | Description |
|---|---|---|
| `mode` | string (required) | One of `searchFacilities`, `facilityRatings`, `facilityInspections`, `searchByState` |
| `state` | string | 2-letter US state code. Required for `searchByState` |
| `searchQuery` | string | Facility name or city keyword |
| `ownershipType` | string | Filter by ownership type |
| `minRating` | integer (1-5) | Minimum overall star rating |
| `specialFocusOnly` | boolean | Only return Special Focus Facilities |
| `maxItems` | integer | Max records to return (default: 20, max: 5000) |

### Output

```json
{
  "providerNumber": "105772",
  "facilityName": "Sunrise Care Center",
  "address": "100 Sunrise Blvd",
  "city": "Miami",
  "state": "FL",
  "zipCode": "33101",
  "countyName": "Miami-Dade",
  "phoneNumber": "3055551234",
  "ownershipType": "For profit - Corporation",
  "bedCount": 120,
  "avgResidentsPerDay": 98.5,
  "rating": 4,
  "healthInspectionRating": 3,
  "staffingRating": 5,
  "qmRating": 4,
  "specialFocusFacility": false,
  "dataSource": "CMS Nursing Home Compare (data.cms.gov)",
  "recordType": "nursingFacility",
  "scrapedAt": "2024-01-15T10:30:00+00:00"
}
```

### FAQs

**Is this free to use?**
Yes. The CMS data.cms.gov API is completely free and public with no registration required.

**How many nursing homes are covered?**
CMS covers approximately 15,000+ certified nursing homes across all US states and territories.

**What is a Special Focus Facility?**
CMS designates facilities with persistent serious quality problems as Special Focus Facilities (SFF). These receive more frequent inspections. This actor can filter to only return SFF-designated facilities.

**What does the star rating mean?**
CMS assigns 1–5 overall ratings combining health inspection results, staffing levels, and quality measures. 5 stars = much above average.

**Does it require login or cookies?**
No. All data comes from the public CMS Provider Data Catalog.

### Data Source

Data is sourced from the [CMS Provider Data Catalog](https://data.cms.gov/provider-data/dataset/4pq5-n9py) — the same data powering [medicare.gov/care-compare](https://www.medicare.gov/care-compare/).

# Actor input Schema

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

What to fetch from CMS Nursing Home Compare data.

## `state` (type: `string`):

Filter by US state abbreviation. Required for mode=searchByState.

## `searchQuery` (type: `string`):

Free-text search across facility name and city.

## `ownershipType` (type: `string`):

Filter by facility ownership.

## `minRating` (type: `integer`):

Only return facilities with this star rating or higher (1-5).

## `specialFocusOnly` (type: `boolean`):

Only return facilities designated as CMS Special Focus Facilities (SFF) — those with persistent quality issues.

## `maxItems` (type: `integer`):

Maximum number of facility records to return.

## Actor input object example

```json
{
  "mode": "searchFacilities",
  "state": "FL",
  "ownershipType": "",
  "specialFocusOnly": false,
  "maxItems": 20
}
```

# Actor output Schema

## `facilities` (type: `string`):

Dataset containing all scraped nursing home/facility 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": "searchFacilities",
    "state": "FL",
    "specialFocusOnly": false,
    "maxItems": 20
};

// Run the Actor and wait for it to finish
const run = await client.actor("crawlerbros/cms-nursing-home-compare-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": "searchFacilities",
    "state": "FL",
    "specialFocusOnly": False,
    "maxItems": 20,
}

# Run the Actor and wait for it to finish
run = client.actor("crawlerbros/cms-nursing-home-compare-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": "searchFacilities",
  "state": "FL",
  "specialFocusOnly": false,
  "maxItems": 20
}' |
apify call crawlerbros/cms-nursing-home-compare-scraper --silent --output-dataset

```

## MCP server setup

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

```

## OpenAPI specification

```json
{
    "openapi": "3.0.1",
    "info": {
        "title": "CMS Nursing Home Compare Scraper",
        "description": "Scrape CMS Nursing Home Compare data via the free data.cms.gov public API. Search nursing homes by state, get star ratings, inspection results, staffing info, and ownership data for all US nursing facilities. No API key required.",
        "version": "1.0",
        "x-build-id": "ojH6nPaDxBGHBpM1R"
    },
    "servers": [
        {
            "url": "https://api.apify.com/v2"
        }
    ],
    "paths": {
        "/acts/crawlerbros~cms-nursing-home-compare-scraper/run-sync-get-dataset-items": {
            "post": {
                "operationId": "run-sync-get-dataset-items-crawlerbros-cms-nursing-home-compare-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~cms-nursing-home-compare-scraper/runs": {
            "post": {
                "operationId": "runs-sync-crawlerbros-cms-nursing-home-compare-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~cms-nursing-home-compare-scraper/run-sync": {
            "post": {
                "operationId": "run-sync-crawlerbros-cms-nursing-home-compare-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": [
                            "searchFacilities",
                            "facilityRatings",
                            "facilityInspections",
                            "searchByState"
                        ],
                        "type": "string",
                        "description": "What to fetch from CMS Nursing Home Compare data.",
                        "default": "searchFacilities"
                    },
                    "state": {
                        "title": "State (2-letter code)",
                        "enum": [
                            "AL",
                            "AK",
                            "AZ",
                            "AR",
                            "CA",
                            "CO",
                            "CT",
                            "DE",
                            "FL",
                            "GA",
                            "HI",
                            "ID",
                            "IL",
                            "IN",
                            "IA",
                            "KS",
                            "KY",
                            "LA",
                            "ME",
                            "MD",
                            "MA",
                            "MI",
                            "MN",
                            "MS",
                            "MO",
                            "MT",
                            "NE",
                            "NV",
                            "NH",
                            "NJ",
                            "NM",
                            "NY",
                            "NC",
                            "ND",
                            "OH",
                            "OK",
                            "OR",
                            "PA",
                            "RI",
                            "SC",
                            "SD",
                            "TN",
                            "TX",
                            "UT",
                            "VT",
                            "VA",
                            "WA",
                            "WV",
                            "WI",
                            "WY",
                            "DC",
                            "PR",
                            "VI",
                            "GU",
                            "MP",
                            "AS"
                        ],
                        "type": "string",
                        "description": "Filter by US state abbreviation. Required for mode=searchByState."
                    },
                    "searchQuery": {
                        "title": "Facility name / city keyword",
                        "type": "string",
                        "description": "Free-text search across facility name and city."
                    },
                    "ownershipType": {
                        "title": "Ownership type",
                        "enum": [
                            "",
                            "For profit - Corporation",
                            "For profit - Individual",
                            "For profit - Limited Liability company",
                            "For profit - Partnership",
                            "Government - City",
                            "Government - City/county",
                            "Government - County",
                            "Government - Federal",
                            "Government - Hospital District",
                            "Government - State",
                            "Non profit - Corporation",
                            "Non profit - Other",
                            "Non profit - Church Related"
                        ],
                        "type": "string",
                        "description": "Filter by facility ownership.",
                        "default": ""
                    },
                    "minRating": {
                        "title": "Minimum overall rating",
                        "minimum": 1,
                        "maximum": 5,
                        "type": "integer",
                        "description": "Only return facilities with this star rating or higher (1-5)."
                    },
                    "specialFocusOnly": {
                        "title": "Special Focus Facilities only",
                        "type": "boolean",
                        "description": "Only return facilities designated as CMS Special Focus Facilities (SFF) — those with persistent quality issues.",
                        "default": false
                    },
                    "maxItems": {
                        "title": "Max items",
                        "minimum": 1,
                        "maximum": 5000,
                        "type": "integer",
                        "description": "Maximum number of facility records to return.",
                        "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
                                    }
                                }
                            }
                        }
                    }
                }
            }
        }
    }
}
```
