# Wolt Restaurant & Venue Scraper (`crawlerbros/wolt-scraper`) Actor

Scrape restaurants, cafes, grocery stores and other venues from Wolt food delivery platform across 27+ countries including Finland, Sweden, Denmark, Germany, Poland, Japan, Israel and more.

- **URL**: https://apify.com/crawlerbros/wolt-scraper.md
- **Developed by:** [Crawler Bros](https://apify.com/crawlerbros) (community)
- **Categories:** Automation, E-commerce, Developer tools
- **Stats:** 3 total users, 2 monthly users, 100.0% runs succeeded, 0 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

## Wolt Restaurant & Venue Scraper

Scrape restaurant and venue data from [Wolt](https://wolt.com/) — a leading food delivery platform operating in 27+ countries across Europe, the Middle East, and Japan. Extract restaurant names, cuisines, ratings, delivery estimates, pricing, locations, and images for any supported city.

### What data you can extract

- **Venue ID, name, and description**
- **Cuisine categories** (Pizza, Sushi, Burger, Grocery, etc.)
- **Rating score and review count**
- **Estimated delivery time** (minutes)
- **Currency and price range** (1=budget to 4=luxury)
- **Online status** (currently accepting orders)
- **Delivery availability**
- **Country and city**
- **Street address**
- **GPS coordinates** (latitude/longitude)
- **URL slug and direct Wolt venue link**
- **Tags/badges** (Popular, New, Exclusive, etc.)
- **Cover image and logo**

### Scraping modes

| Mode | Description |
|---|---|
| `byCity` | Scrape all venues in a supported city (1000+ results) |
| `byUrl` | Scrape specific Wolt venue profile URLs |

### Supported cities (27+)

**Europe:** Helsinki, Stockholm, Oslo, Copenhagen, Warsaw, Prague, Budapest, Berlin, Hamburg, Munich, Frankfurt, Cologne, Tallinn, Riga, Vilnius, Reykjavik, Zagreb, Ljubljana, Bratislava

**Middle East:** Tel Aviv, Jerusalem, Haifa, Nicosia, Limassol

**Asia:** Tokyo

**Nordic/Other:** Athens, Thessaloniki

### Input configuration

| Field | Type | Description |
|---|---|---|
| `mode` | Select | Scraping mode (byCity / byUrl) |
| `city` | Select | Target city (for byCity mode) |
| `venueUrls` | List | Direct Wolt venue URLs (for byUrl mode) |
| `categoryFilter` | Text | Filter by cuisine/category keyword (e.g. "pizza", "sushi") |
| `onlineOnly` | Boolean | Only return venues currently accepting orders |
| `maxItems` | Number | Maximum number of results (1–2000, default 100) |

### Example input

```json
{
  "mode": "byCity",
  "city": "helsinki",
  "categoryFilter": "pizza",
  "onlineOnly": true,
  "maxItems": 100
}
````

### Example output

```json
{
  "venueId": "5e25d0d6cafebabe4afb2a01",
  "name": "Pizza Palace",
  "shortDescription": "Best pizza in Helsinki",
  "categories": ["Pizza", "Italian", "Pasta"],
  "rating": 8.7,
  "ratingCount": 1523,
  "estimateMinutes": 35,
  "currency": "EUR",
  "priceRange": 2,
  "online": true,
  "delivers": true,
  "country": "fin",
  "city": "helsinki",
  "address": "Mannerheimintie 5, Helsinki",
  "latitude": 60.1699,
  "longitude": 24.9384,
  "slug": "pizza-palace-helsinki",
  "tags": ["Popular"],
  "imageUrl": "https://imageproxy.wolt.com/venue/5e25d0d6/cover.jpg",
  "profileImageUrl": "https://imageproxy.wolt.com/venue/5e25d0d6/logo.jpg",
  "venueUrl": "https://wolt.com/en/fin/helsinki/restaurant/pizza-palace-helsinki",
  "recordType": "venue",
  "sourceUrl": "https://consumer-api.wolt.com/v1/pages/restaurants?lat=60.1699&lon=24.9384&slug=helsinki",
  "scrapedAt": "2026-06-01T12:00:00+00:00"
}
```

### Use cases

- **Food delivery market research** — analyze restaurant density, cuisine types, and ratings by city
- **Competitor analysis** — track competing restaurants' ratings, pricing, and delivery performance
- **Location intelligence** — discover which cuisines are most popular in each city
- **Brand monitoring** — track your restaurant's rating and position on Wolt
- **Market entry research** — identify cuisine gaps and opportunities in target cities
- **Price benchmarking** — compare price ranges across cuisine types and cities

### FAQ

**Does it require login or API keys?**
No. Wolt's venue data is publicly accessible without authentication.

**How many venues can I get per city?**
Typically 500–1500 venues depending on the city size. Helsinki and Berlin have 1000+ venues.

**How do I filter by cuisine type?**
Use the `categoryFilter` input — it matches any keyword in the venue's tags (e.g., "pizza", "sushi", "burger", "grocery", "coffee").

**Can I check which restaurants are currently open?**
Yes — set `onlineOnly: true` to only return venues currently accepting orders.

**What is the price range scale?**
1 = budget-friendly, 2 = moderate, 3 = premium, 4 = luxury.

**Are all Wolt cities supported?**
The 27 cities listed cover all major Wolt markets. Wolt continues expanding — contact us if you need a specific city added.

**Can I track a specific restaurant's rating over time?**
Yes — run the scraper daily and filter by venue name or slug to track rating changes.

# Actor input Schema

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

byCity: scrape all venues in a city. byUrl: scrape specific Wolt venue profile URLs.

## `city` (type: `string`):

City to scrape venues from. Used in byCity mode.

## `venueUrls` (type: `array`):

List of Wolt venue profile URLs to scrape directly (e.g. https://wolt.com/en/fin/helsinki/restaurant/my-restaurant).

## `categoryFilter` (type: `string`):

Only include venues whose category matches this keyword (e.g. 'pizza', 'sushi', 'grocery'). Case-insensitive.

## `onlineOnly` (type: `boolean`):

Only return venues that are currently accepting orders.

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

Maximum number of venues to return (1–2000).

## Actor input object example

```json
{
  "mode": "byCity",
  "city": "helsinki",
  "onlineOnly": false,
  "maxItems": 50
}
```

# Actor output Schema

## `venues` (type: `string`):

Dataset containing all scraped venue 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": "byCity",
    "city": "helsinki",
    "onlineOnly": false,
    "maxItems": 50
};

// Run the Actor and wait for it to finish
const run = await client.actor("crawlerbros/wolt-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": "byCity",
    "city": "helsinki",
    "onlineOnly": False,
    "maxItems": 50,
}

# Run the Actor and wait for it to finish
run = client.actor("crawlerbros/wolt-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": "byCity",
  "city": "helsinki",
  "onlineOnly": false,
  "maxItems": 50
}' |
apify call crawlerbros/wolt-scraper --silent --output-dataset

```

## MCP server setup

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

```

## OpenAPI specification

```json
{
    "openapi": "3.0.1",
    "info": {
        "title": "Wolt Restaurant & Venue Scraper",
        "description": "Scrape restaurants, cafes, grocery stores and other venues from Wolt food delivery platform across 27+ countries including Finland, Sweden, Denmark, Germany, Poland, Japan, Israel and more.",
        "version": "0.1",
        "x-build-id": "8Uhx1WtMEcD680hPD"
    },
    "servers": [
        {
            "url": "https://api.apify.com/v2"
        }
    ],
    "paths": {
        "/acts/crawlerbros~wolt-scraper/run-sync-get-dataset-items": {
            "post": {
                "operationId": "run-sync-get-dataset-items-crawlerbros-wolt-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~wolt-scraper/runs": {
            "post": {
                "operationId": "runs-sync-crawlerbros-wolt-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~wolt-scraper/run-sync": {
            "post": {
                "operationId": "run-sync-crawlerbros-wolt-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": "Scraping Mode",
                        "enum": [
                            "byCity",
                            "byUrl"
                        ],
                        "type": "string",
                        "description": "byCity: scrape all venues in a city. byUrl: scrape specific Wolt venue profile URLs.",
                        "default": "byCity"
                    },
                    "city": {
                        "title": "City",
                        "enum": [
                            "helsinki",
                            "stockholm",
                            "oslo",
                            "copenhagen",
                            "warsaw",
                            "prague",
                            "budapest",
                            "berlin",
                            "hamburg",
                            "munich",
                            "frankfurt",
                            "cologne",
                            "tokyo",
                            "tel-aviv",
                            "jerusalem",
                            "haifa",
                            "thessaloniki",
                            "athens",
                            "tallinn",
                            "riga",
                            "vilnius",
                            "reykjavik",
                            "zagreb",
                            "ljubljana",
                            "bratislava",
                            "nicosia",
                            "limassol"
                        ],
                        "type": "string",
                        "description": "City to scrape venues from. Used in byCity mode.",
                        "default": "helsinki"
                    },
                    "venueUrls": {
                        "title": "Venue URLs (for byUrl mode)",
                        "type": "array",
                        "description": "List of Wolt venue profile URLs to scrape directly (e.g. https://wolt.com/en/fin/helsinki/restaurant/my-restaurant).",
                        "items": {
                            "type": "string"
                        }
                    },
                    "categoryFilter": {
                        "title": "Category Filter",
                        "type": "string",
                        "description": "Only include venues whose category matches this keyword (e.g. 'pizza', 'sushi', 'grocery'). Case-insensitive."
                    },
                    "onlineOnly": {
                        "title": "Online Only",
                        "type": "boolean",
                        "description": "Only return venues that are currently accepting orders.",
                        "default": false
                    },
                    "maxItems": {
                        "title": "Maximum Items",
                        "minimum": 1,
                        "maximum": 2000,
                        "type": "integer",
                        "description": "Maximum number of venues to return (1–2000).",
                        "default": 100
                    }
                }
            },
            "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
                                    }
                                }
                            }
                        }
                    }
                }
            }
        }
    }
}
```
