# Zoopla Scraper — UK Property Listings, Prices & Agents (`studio-amba/zoopla-scraper`) Actor

Scrape property listings from Zoopla.co.uk — the UK's #2 real estate portal. Search for-sale or to-rent by location. Get prices, addresses, bedrooms, bathrooms, floor area, images, estate agent details, and more. No login or cookies required.

- **URL**: https://apify.com/studio-amba/zoopla-scraper.md
- **Developed by:** [Studio Amba](https://apify.com/studio-amba) (community)
- **Categories:** Real estate
- **Stats:** 2 total users, 1 monthly users, 100.0% runs succeeded, NaN 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

## Zoopla Scraper

Scrape **property listings** from [Zoopla.co.uk](https://www.zoopla.co.uk) — the UK's second-largest real estate portal. Extract prices, addresses, bedrooms, bathrooms, floor area, images, and estate agent details for both **for-sale** and **to-rent** properties. No login or cookies required.

### What does Zoopla Scraper do?

This Actor lets you **extract structured property data** from Zoopla search results at scale. Search by any UK location (city, town, postcode area) and listing type. Get clean JSON output with all the key fields you need for property analysis, market research, or lead generation.

Run it on the Apify platform for **scheduled scraping, API access, webhook integrations**, and automatic proxy rotation.

### Why use Zoopla Scraper?

- **Market research** — track property prices across UK regions over time
- **Lead generation** — find estate agents actively listing properties in target areas
- **Investment analysis** — compare asking prices, property sizes, and bedroom counts
- **Data journalism** — build datasets on housing affordability by location
- **Portfolio monitoring** — track new listings matching your investment criteria

### How to use Zoopla Scraper

1. Click **Try for free** to open the Actor in Apify Console
2. Enter a **location** (e.g., "london", "manchester", "bristol")
3. Choose a **listing type** (For Sale or To Rent)
4. Set the **maximum number of results** you need
5. Click **Start** and wait for results
6. Download your data as JSON, CSV, Excel, or connect via API

### Input

| Field | Type | Required | Description |
|-------|------|----------|-------------|
| `location` | String | No | UK location to search (default: "london") |
| `startUrls` | Array | No | Zoopla search URLs to scrape directly |
| `listingType` | String | No | `for-sale` (default) or `to-rent` |
| `maxResults` | Integer | No | Maximum listings to return (default: 100) |
| `proxyConfiguration` | Object | No | Proxy settings for reliable scraping |

### Output

Each result contains:

| Field | Type | Example |
|-------|------|---------|
| `title` | String | `"2 bed flat for sale"` |
| `price` | Number | `399950` |
| `currency` | String | `"GBP"` |
| `listingType` | String | `"sale"` |
| `propertyType` | String | `"flat"` |
| `address` | String | `"Marner Point, Bromley-By-Bow, London E3"` |
| `city` | String | `"London"` |
| `postalCode` | String | `"E3"` |
| `bedrooms` | Number | `2` |
| `bathrooms` | Number | `2` |
| `surface` | Number | `586` |
| `imageUrl` | String | Primary listing image URL |
| `imageUrls` | Array | All listing image URLs |
| `agencyName` | String | `"Savills"` |
| `url` | String | Full listing URL |
| `scrapedAt` | String | `"2026-04-06T12:00:00.000Z"` |

### Example output

```json
{
    "title": "2 bed flat for sale",
    "price": 399950,
    "currency": "GBP",
    "listingType": "sale",
    "propertyType": "flat",
    "address": "Marner Point, Jefferson Plaza, Bromley-By-Bow, London E3",
    "city": "London",
    "postalCode": "E3",
    "bedrooms": 2,
    "bathrooms": 2,
    "surface": 720,
    "imageUrl": "https://lid.zoocdn.com/u/480/360/example.jpg",
    "agencyName": "Savills",
    "url": "https://www.zoopla.co.uk/for-sale/details/72573752/",
    "scrapedAt": "2026-04-06T12:00:00.000Z"
}
````

You can download the dataset in various formats such as JSON, HTML, CSV, or Excel.

### How much does it cost to scrape Zoopla?

This Actor uses lightweight HTTP requests (no browser) making it very efficient. Approximate costs:

| Results | Estimated cost |
|---------|---------------|
| 100 | ~$0.01 |
| 1,000 | ~$0.05 |
| 10,000 | ~$0.30 |

Costs depend on proxy usage and Apify platform pricing.

### Tips for best results

- **Start with a small run** to verify the data matches your needs
- **Use specific locations** (e.g., "bristol" instead of all UK) for faster, targeted results
- **Schedule regular runs** to track new listings over time
- **Use the API** to integrate Zoopla data into your own applications or dashboards

### FAQ and support

**Is it legal to scrape Zoopla?**
This Actor extracts publicly available data from Zoopla.co.uk. Always ensure your use case complies with applicable laws and the website's terms of service.

**The Actor returned fewer results than expected**
Some searches may return fewer results due to Zoopla's own filtering. Try broadening your location or adjusting the listing type.

**I need help or have a feature request**
Open an issue in the [Issues tab](https://console.apify.com/actors/issues) or contact support. We also build custom scraping solutions on request.

# Actor input Schema

## `location` (type: `string`):

Search for properties by location, e.g., 'london', 'manchester', 'birmingham', 'bristol'. Used to build the search URL.

## `startUrls` (type: `array`):

Zoopla search result URLs to scrape. Overrides location if provided.

## `listingType` (type: `string`):

Type of listing to search for.

## `maxResults` (type: `integer`):

Maximum number of listings to return.

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

Proxy settings for reliable scraping.

## Actor input object example

```json
{
  "location": "london",
  "startUrls": [
    {
      "url": "https://www.zoopla.co.uk/for-sale/property/london/"
    }
  ],
  "listingType": "for-sale",
  "maxResults": 100
}
```

# Actor output Schema

## `dataset` (type: `string`):

No description

# 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 = {
    "location": "london",
    "startUrls": [
        {
            "url": "https://www.zoopla.co.uk/for-sale/property/london/"
        }
    ]
};

// Run the Actor and wait for it to finish
const run = await client.actor("studio-amba/zoopla-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 = {
    "location": "london",
    "startUrls": [{ "url": "https://www.zoopla.co.uk/for-sale/property/london/" }],
}

# Run the Actor and wait for it to finish
run = client.actor("studio-amba/zoopla-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 '{
  "location": "london",
  "startUrls": [
    {
      "url": "https://www.zoopla.co.uk/for-sale/property/london/"
    }
  ]
}' |
apify call studio-amba/zoopla-scraper --silent --output-dataset

```

## MCP server setup

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

```

## OpenAPI specification

```json
{
    "openapi": "3.0.1",
    "info": {
        "title": "Zoopla Scraper — UK Property Listings, Prices & Agents",
        "description": "Scrape property listings from Zoopla.co.uk — the UK's #2 real estate portal. Search for-sale or to-rent by location. Get prices, addresses, bedrooms, bathrooms, floor area, images, estate agent details, and more. No login or cookies required.",
        "version": "0.1",
        "x-build-id": "hAvWVY10SHPqgByE8"
    },
    "servers": [
        {
            "url": "https://api.apify.com/v2"
        }
    ],
    "paths": {
        "/acts/studio-amba~zoopla-scraper/run-sync-get-dataset-items": {
            "post": {
                "operationId": "run-sync-get-dataset-items-studio-amba-zoopla-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/studio-amba~zoopla-scraper/runs": {
            "post": {
                "operationId": "runs-sync-studio-amba-zoopla-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/studio-amba~zoopla-scraper/run-sync": {
            "post": {
                "operationId": "run-sync-studio-amba-zoopla-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",
                "properties": {
                    "location": {
                        "title": "Location",
                        "type": "string",
                        "description": "Search for properties by location, e.g., 'london', 'manchester', 'birmingham', 'bristol'. Used to build the search URL."
                    },
                    "startUrls": {
                        "title": "Start URLs",
                        "type": "array",
                        "description": "Zoopla search result URLs to scrape. Overrides location if provided.",
                        "items": {
                            "type": "object",
                            "required": [
                                "url"
                            ],
                            "properties": {
                                "url": {
                                    "type": "string",
                                    "title": "URL of a web page",
                                    "format": "uri"
                                }
                            }
                        }
                    },
                    "listingType": {
                        "title": "Listing Type",
                        "enum": [
                            "for-sale",
                            "to-rent"
                        ],
                        "type": "string",
                        "description": "Type of listing to search for.",
                        "default": "for-sale"
                    },
                    "maxResults": {
                        "title": "Max Results",
                        "minimum": 1,
                        "maximum": 50000,
                        "type": "integer",
                        "description": "Maximum number of listings to return.",
                        "default": 100
                    },
                    "proxyConfiguration": {
                        "title": "Proxy Configuration",
                        "type": "object",
                        "description": "Proxy settings for reliable scraping."
                    }
                }
            },
            "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
                                    }
                                }
                            }
                        }
                    }
                }
            }
        }
    }
}
```
