# Viator Scraper: Tours, Activities, Prices, Reviews (`scrapemint/viator-tours-tracker`) Actor

Scrape Viator tours and activities by destination, keyword, or product URL. Returns price from, rating, review count, duration, highlights, category, and bookable status for every listing. Filter by minimum rating, reviews, price range. JSON output.

- **URL**: https://apify.com/scrapemint/viator-tours-tracker.md
- **Developed by:** [Kennedy Mutisya](https://apify.com/scrapemint) (community)
- **Categories:** Automation, Developer tools, E-commerce
- **Stats:** 2 total users, 1 monthly users, 0.0% runs succeeded, 1 bookmarks
- **User rating**: No ratings yet

## Pricing

Pay per usage

This Actor is paid per platform usage. The Actor is free to use, and you only pay for the Apify platform usage, which gets cheaper the higher subscription plan you have.

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

## 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

## Viator Scraper: Tours, Activities, Prices, and Reviews

Pull Viator tours and activities by destination, keyword, or product URL. Every row has price from, star rating, review count, duration, highlights, supplier, category, and free cancellation flag. Works for Paris, London, Rome, Tokyo, New York, Dubai, and every Viator city. JSON output. Pay per item.

**Ranks for:** Viator scraper, Viator API, tour price tracker, travel activity data, TripAdvisor experiences, destination tour feed, sightseeing price monitor, attraction booking data.

---

### How it works

```mermaid
flowchart LR
    A[Destination URL<br/>or keyword] --> B[Viator page]
    B --> C[Parse embedded<br/>tour JSON]
    C --> D[Filter rating<br/>reviews, price]
    D --> E[JSON dataset]
````

Paste a Viator destination URL. One row per tour, deduped by product code.

***

### Who uses this

| Role | Use case |
|---|---|
| **Tour operator** | Watch rival prices in your city. Alert on undercuts. |
| **OTA / affiliate site** | Power a top tours widget without Viator Partner API approval. |
| **Destination marketing org** | Measure which tours rank highest by category. |
| **Travel journalist** | Pull best reviewed experiences for a city guide. |
| **Concierge software** | Feed curated things to do into a hotel guest app. |

***

### Quick start

**Top Paris tours:**

```json
{
  "destinationUrls": ["https://www.viator.com/Paris/d479-ttd"],
  "minRating": 4.5,
  "minReviewCount": 200
}
```

**Keyword search:**

```json
{
  "searchQueries": ["cooking class rome", "sunset cruise dubai"],
  "minRating": 4.7
}
```

**Premium only:**

```json
{
  "destinationUrls": ["https://www.viator.com/Dubai/d828-ttd"],
  "minPriceUsd": 200
}
```

***

### Popular destinations

| City | URL |
|---|---|
| Paris | `viator.com/Paris/d479-ttd` |
| London | `viator.com/London/d737-ttd` |
| Rome | `viator.com/Rome/d511-ttd` |
| New York | `viator.com/New-York-City/d687-ttd` |
| Tokyo | `viator.com/Tokyo/d334-ttd` |
| Dubai | `viator.com/Dubai/d828-ttd` |
| Barcelona | `viator.com/Barcelona/d562-ttd` |
| Bangkok | `viator.com/Bangkok/d343-ttd` |
| Amsterdam | `viator.com/Amsterdam/d525-ttd` |
| Istanbul | `viator.com/Istanbul/d585-ttd` |

Any Viator city works. Copy the URL from viator.com.

***

### Output flags

```mermaid
flowchart LR
    A[Tour row] --> B[highly_rated<br/>4.8+ with 200+ reviews]
    A --> C[bestseller<br/>Viator badge]
    A --> D[new_listing<br/>under 10 reviews]
    A --> E[skip_the_line]
    A --> F[budget / premium<br/>$20 / $200+]
```

Each row has a `flags` array so pipelines filter without parsing titles.

***

### Viator scraper vs the alternatives

| | Viator Partner API | Manual copy paste | **This actor** |
|---|---|---|---|
| Access | Affiliate approval | Anyone | Anyone |
| Setup | Weeks of paperwork | None | 60 seconds |
| Price + reviews | Yes | Yes, slow | Yes |
| Schedule | Yes | Hire an intern | Every 60s |
| JSON output | Yes | No | Yes |
| Pricing | Rev share | Time | Pay per item |

***

### Sample output

```json
{
  "productCode": "2050XPACKAGE",
  "title": "Skip the Line: Eiffel Tower Summit Access",
  "destinationName": "Paris",
  "destinationId": 479,
  "primaryCategory": "Tours & Sightseeing",
  "durationMinutes": 90,
  "durationLabel": "1h 30m",
  "priceFrom": 79.5,
  "priceCurrency": "USD",
  "rating": 4.6,
  "reviewCount": 5421,
  "freeCancellation": true,
  "supplier": "Paris Tours Inc",
  "highlights": ["Skip the main line", "Summit access", "Small group"],
  "flags": ["highly_rated", "skip_the_line"],
  "url": "https://www.viator.com/tours/Paris/..."
}
```

***

### Pricing

First 50 items per run are free. After that you pay per tour row. A 200 row Paris snapshot lands under $1.

***

### FAQ

**Do I need a Viator API key?**
No. The actor reads public Viator pages.

**Can I track price changes over time?**
Yes. Set `dedupe: false` and schedule every 60 minutes. Each run writes a fresh snapshot with a `scrapedAt` timestamp.

**Which cities are covered?**
Every Viator city (2500+). Paste any destination URL.

**How is price extracted?**
Viator shows a from price per tour. The actor returns `priceFrom` in the page currency (usually USD).

**Does Viator block scrapers?**
Viator runs Cloudflare. The actor ships with residential proxy enabled by default. If you run at high volume and see 403s, rotate proxy groups or lower concurrency.

**Is scraping Viator allowed?**
This actor reads the same public HTML a browser sees. Respect the site's terms of service and rate limit sensibly.

***

### Related Scrapemint actors

- **TripAdvisor Review Intelligence** for hotel and restaurant reviews
- **Airbnb Market Intelligence** for short term rental data
- **Booking Review Intelligence** for hotel reviews by city
- **Google Reviews Intelligence** for places reviews
- **Yelp Review Intelligence** for US local business reviews
- **Trustpilot Brand Reputation** for brand review monitoring

Stack these to cover every public travel and hospitality surface.

# Actor input Schema

## `destinationUrls` (type: `array`):

Full Viator destination URLs. Example: https://www.viator.com/Paris/d479-ttd, https://www.viator.com/London/d737-ttd. Find the URL for any city by browsing viator.com.

## `searchQueries` (type: `array`):

Keyword searches like "cooking class paris", "sunset cruise dubai", "vatican skip the line". Uses Viator's own search.

## `productUrls` (type: `array`):

Direct Viator product page URLs to pull. Use when you want exact listings (price history, reviews on a specific tour).

## `minRating` (type: `number`):

Drop tours with a rating below this (out of 5). 4.5 is the sweet spot for top picks.

## `minReviewCount` (type: `integer`):

Drop tours with fewer than this many reviews. 50 filters out brand new listings. 500+ only returns best sellers.

## `maxPriceUsd` (type: `number`):

Drop tours priced above this. Use with minPriceUsd for price brackets.

## `minPriceUsd` (type: `number`):

Drop tours priced below this. Useful to exclude free city walks when searching premium experiences.

## `languageCode` (type: `string`):

Viator language code. en = English, es = Spanish, fr = French, de = German, it = Italian, pt = Portuguese, ja = Japanese, zh = Chinese.

## `maxItemsPerSource` (type: `integer`):

Per destination or per query cap on rows pushed. Each destination page typically has 30 to 50 featured tours.

## `maxItemsTotal` (type: `integer`):

Hard cap on rows pushed to the dataset per run. Controls total cost.

## `dedupe` (type: `boolean`):

Skip product codes pushed on previous runs. Stored in the key value store under SEEN\_IDS. Turn off to track price changes over time.

## `proxyConfiguration` (type: `object`):

Apify proxy. Residential group recommended if you run every few minutes or hit rate limits.

## Actor input object example

```json
{
  "destinationUrls": [
    "https://www.viator.com/Paris/d479-ttd"
  ],
  "searchQueries": [],
  "productUrls": [],
  "minRating": 0,
  "minReviewCount": 0,
  "maxPriceUsd": 0,
  "minPriceUsd": 0,
  "languageCode": "en",
  "maxItemsPerSource": 50,
  "maxItemsTotal": 200,
  "dedupe": true,
  "proxyConfiguration": {
    "useApifyProxy": true,
    "apifyProxyGroups": [
      "RESIDENTIAL"
    ]
  }
}
```

# 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 = {
    "destinationUrls": [
        "https://www.viator.com/Paris/d479-ttd"
    ]
};

// Run the Actor and wait for it to finish
const run = await client.actor("scrapemint/viator-tours-tracker").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 = { "destinationUrls": ["https://www.viator.com/Paris/d479-ttd"] }

# Run the Actor and wait for it to finish
run = client.actor("scrapemint/viator-tours-tracker").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 '{
  "destinationUrls": [
    "https://www.viator.com/Paris/d479-ttd"
  ]
}' |
apify call scrapemint/viator-tours-tracker --silent --output-dataset

```

## MCP server setup

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

```

## OpenAPI specification

```json
{
    "openapi": "3.0.1",
    "info": {
        "title": "Viator Scraper: Tours, Activities, Prices, Reviews",
        "description": "Scrape Viator tours and activities by destination, keyword, or product URL. Returns price from, rating, review count, duration, highlights, category, and bookable status for every listing. Filter by minimum rating, reviews, price range. JSON output.",
        "version": "0.1",
        "x-build-id": "lgwWR8fsSramtZWwe"
    },
    "servers": [
        {
            "url": "https://api.apify.com/v2"
        }
    ],
    "paths": {
        "/acts/scrapemint~viator-tours-tracker/run-sync-get-dataset-items": {
            "post": {
                "operationId": "run-sync-get-dataset-items-scrapemint-viator-tours-tracker",
                "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/scrapemint~viator-tours-tracker/runs": {
            "post": {
                "operationId": "runs-sync-scrapemint-viator-tours-tracker",
                "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/scrapemint~viator-tours-tracker/run-sync": {
            "post": {
                "operationId": "run-sync-scrapemint-viator-tours-tracker",
                "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",
                "properties": {
                    "destinationUrls": {
                        "title": "Destination URLs",
                        "type": "array",
                        "description": "Full Viator destination URLs. Example: https://www.viator.com/Paris/d479-ttd, https://www.viator.com/London/d737-ttd. Find the URL for any city by browsing viator.com.",
                        "items": {
                            "type": "string"
                        }
                    },
                    "searchQueries": {
                        "title": "Search queries",
                        "type": "array",
                        "description": "Keyword searches like \"cooking class paris\", \"sunset cruise dubai\", \"vatican skip the line\". Uses Viator's own search.",
                        "default": [],
                        "items": {
                            "type": "string"
                        }
                    },
                    "productUrls": {
                        "title": "Product URLs",
                        "type": "array",
                        "description": "Direct Viator product page URLs to pull. Use when you want exact listings (price history, reviews on a specific tour).",
                        "default": [],
                        "items": {
                            "type": "string"
                        }
                    },
                    "minRating": {
                        "title": "Minimum rating",
                        "minimum": 0,
                        "maximum": 5,
                        "type": "number",
                        "description": "Drop tours with a rating below this (out of 5). 4.5 is the sweet spot for top picks.",
                        "default": 0
                    },
                    "minReviewCount": {
                        "title": "Minimum review count",
                        "minimum": 0,
                        "type": "integer",
                        "description": "Drop tours with fewer than this many reviews. 50 filters out brand new listings. 500+ only returns best sellers.",
                        "default": 0
                    },
                    "maxPriceUsd": {
                        "title": "Maximum price ($)",
                        "minimum": 0,
                        "type": "number",
                        "description": "Drop tours priced above this. Use with minPriceUsd for price brackets.",
                        "default": 0
                    },
                    "minPriceUsd": {
                        "title": "Minimum price ($)",
                        "minimum": 0,
                        "type": "number",
                        "description": "Drop tours priced below this. Useful to exclude free city walks when searching premium experiences.",
                        "default": 0
                    },
                    "languageCode": {
                        "title": "Language code",
                        "enum": [
                            "en",
                            "es",
                            "fr",
                            "de",
                            "it",
                            "pt",
                            "ja",
                            "zh"
                        ],
                        "type": "string",
                        "description": "Viator language code. en = English, es = Spanish, fr = French, de = German, it = Italian, pt = Portuguese, ja = Japanese, zh = Chinese.",
                        "default": "en"
                    },
                    "maxItemsPerSource": {
                        "title": "Max items per source",
                        "minimum": 1,
                        "maximum": 500,
                        "type": "integer",
                        "description": "Per destination or per query cap on rows pushed. Each destination page typically has 30 to 50 featured tours.",
                        "default": 50
                    },
                    "maxItemsTotal": {
                        "title": "Maximum items per run",
                        "minimum": 1,
                        "maximum": 5000,
                        "type": "integer",
                        "description": "Hard cap on rows pushed to the dataset per run. Controls total cost.",
                        "default": 200
                    },
                    "dedupe": {
                        "title": "Deduplicate across runs",
                        "type": "boolean",
                        "description": "Skip product codes pushed on previous runs. Stored in the key value store under SEEN_IDS. Turn off to track price changes over time.",
                        "default": true
                    },
                    "proxyConfiguration": {
                        "title": "Proxy configuration",
                        "type": "object",
                        "description": "Apify proxy. Residential group recommended if you run every few minutes or hit rate limits.",
                        "default": {
                            "useApifyProxy": true,
                            "apifyProxyGroups": [
                                "RESIDENTIAL"
                            ]
                        }
                    }
                }
            },
            "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
                                    }
                                }
                            }
                        }
                    }
                }
            }
        }
    }
}
```
