# Daft.ie Scraper — Irish Real Estate Listings (`studio-amba/daft-scraper`) Actor

Scrape real estate listings from Daft.ie — Ireland's largest property portal. Get prices, addresses, BER ratings, coordinates, photos, and agent info for properties for sale, rent, or sharing. No login or cookies required.

- **URL**: https://apify.com/studio-amba/daft-scraper.md
- **Developed by:** [Studio Amba](https://apify.com/studio-amba) (community)
- **Categories:** E-commerce
- **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

## Daft.ie Scraper

Scrape real estate listings from Daft.ie — Ireland's largest and most popular property portal. No login or cookies required.

### How to scrape Daft.ie data

This actor uses Daft.ie's internal API to extract structured property listings at scale. Simply enter a location (like "Dublin" or "Cork"), choose whether you want sales, rentals, or sharing listings, and the actor returns clean JSON data ready for analysis.

It works for all Irish counties and major cities, returning prices, addresses, BER energy ratings, GPS coordinates, bedroom/bathroom counts, floor area, photos, and estate agent information.

### Why use this actor?

- **Real estate investors** tracking Irish property prices and market trends
- **Proptech companies** building Irish property databases or comparison tools
- **Market researchers** analyzing asking prices, supply, and demand by region
- **Relocation services** compiling rental availability for clients moving to Ireland
- **Data journalists** covering the Irish housing market

### Features

- Searches all of Ireland: every county and major city
- Supports sale, rent, and sharing listing types
- Filters by property type, price range, and minimum bedrooms
- Returns GPS coordinates for map-based analysis
- Includes BER (Building Energy Rating) for energy efficiency analysis
- Extracts agent/agency information for lead generation
- Fast API-based extraction (no browser needed)
- Handles pagination automatically
- Built-in output validation and error detection

### Input

| Field | Type | Required | Default | Description |
|-------|------|----------|---------|-------------|
| `searchQuery` | String | No | `Dublin` | Location to search (county or city name) |
| `listingType` | String | No | `sale` | `sale`, `rent`, or `sharing` |
| `propertyType` | String | No | `all` | Property type filter (houses, apartments, studios, etc.) |
| `minPrice` | Integer | No | — | Minimum price in EUR |
| `maxPrice` | Integer | No | — | Maximum price in EUR |
| `minBeds` | Integer | No | — | Minimum number of bedrooms |
| `maxResults` | Integer | No | `100` | Maximum number of listings to return |
| `proxyConfiguration` | Object | No | IE residential | Proxy settings |

#### Supported locations

You can search by county name (`Dublin`, `Cork`, `Galway`, `Limerick`, `Kerry`, `Mayo`, `Waterford`, `Wicklow`, `Meath`, `Kildare`, `Tipperary`, `Donegal`, `Clare`, `Kilkenny`, `Louth`, and all other Irish counties) or by city (`Dublin City Centre`, `Cork City`, `Galway City`, `Limerick City`).

#### Supported property types

`all`, `houses`, `apartments`, `studios`, `duplexes`, `bungalows`, `detached`, `semi-detached`, `terraced`, `townhouses`, `sites`

### Output

Each result contains:

| Field | Type | Example |
|-------|------|---------|
| `title` | String | `"3 Bed Semi-Detached House, Riverside Drive, Dublin 14"` |
| `price` | Number | `475000` |
| `currency` | String | `"EUR"` |
| `listingType` | String | `"sale"` |
| `propertyType` | String | `"houses"` |
| `address` | String | `"3 Bed Semi-Detached House, Riverside Drive, Dublin 14"` |
| `city` | String | `"Dublin"` |
| `county` | String | `"Dublin"` |
| `eircode` | String | `null` |
| `latitude` | Number | `53.2951` |
| `longitude` | Number | `-6.2622` |
| `bedrooms` | Number | `3` |
| `bathrooms` | Number | `2` |
| `surface` | Number | `110` |
| `berRating` | String | `"C1"` |
| `imageUrl` | String | Primary listing photo URL |
| `imageUrls` | Array | All listing photo URLs |
| `description` | String | `null` (not in search API) |
| `agencyName` | String | `"Sherry FitzGerald"` |
| `agencyUrl` | String | Agent profile URL |
| `publishedDate` | String | `"2026-05-15T10:30:00.000Z"` |
| `url` | String | Full listing URL on Daft.ie |
| `scrapedAt` | String | `"2026-05-27T12:00:00.000Z"` |

### Example output

```json
{
    "title": "3 Bed Semi-Detached House, Riverside Drive, Rathfarnham, Dublin 14",
    "price": 475000,
    "currency": "EUR",
    "listingType": "sale",
    "propertyType": "houses",
    "address": "3 Bed Semi-Detached House, Riverside Drive, Rathfarnham, Dublin 14",
    "city": "Dublin",
    "county": "Dublin",
    "eircode": null,
    "latitude": 53.2951,
    "longitude": -6.2622,
    "bedrooms": 3,
    "bathrooms": 2,
    "surface": 110,
    "berRating": "C1",
    "imageUrl": "https://media.daft.ie/photo/12345.jpg",
    "imageUrls": [
        "https://media.daft.ie/photo/12345.jpg",
        "https://media.daft.ie/photo/12346.jpg"
    ],
    "description": null,
    "agencyName": "Sherry FitzGerald",
    "agencyUrl": "https://www.daft.ie/estate-agent/12345/",
    "publishedDate": "2026-05-15T10:30:00.000Z",
    "url": "https://www.daft.ie/for-sale/semi-detached-house-riverside-drive-rathfarnham-dublin-14/12345",
    "scrapedAt": "2026-05-27T12:00:00.000Z"
}
````

### Cost estimate

This actor uses direct HTTP requests to Daft.ie's API (no browser needed), making it very efficient. Expect approximately **0.5-1 compute unit per 1,000 results**. At standard Apify pricing, that's roughly **$0.01-0.05 per 1,000 listings**.

### Limitations

- Location search maps common names to Daft.ie's internal IDs. If your specific area is not recognized, try the county name instead.
- The `description` field is not available in search results (only on individual listing pages). This keeps the actor fast and cost-effective.
- Eircode (Irish postal code) is not consistently provided by Daft.ie in search results.
- Price is extracted as a number; for rentals, this is the monthly asking rent (not weekly).
- Daft.ie may rate-limit aggressive scraping. The actor includes built-in delays and retry logic.

### Use cases

- **Price tracking** — monitor asking prices across Irish counties and property types over time.
- **Rental yield analysis** — combine sale and rent data to calculate gross rental yields by area.
- **Supply monitoring** — track how many new listings appear each week in target locations.
- **Agency intelligence** — analyze which agents are most active in specific areas.
- **Energy efficiency research** — use BER ratings to study the energy profile of Irish housing stock.
- **Geographic analysis** — use GPS coordinates to map listings and identify pricing patterns.

### Support

Hit a bug or a missing field? Open an issue on the Actor page — we respond fast and ship fixes within 24 hours. Every published scraper in the Studio Amba catalog is monitored daily; broken runs trigger an automatic heal cycle.

# Actor input Schema

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

Location to search (e.g. 'Dublin', 'Cork City', 'Galway'). Maps to Daft.ie's location filter.

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

Type of listing to search for.

## `propertyType` (type: `string`):

Filter by property type.

## `minPrice` (type: `integer`):

Minimum price filter in EUR.

## `maxPrice` (type: `integer`):

Maximum price filter in EUR.

## `minBeds` (type: `integer`):

Minimum number of bedrooms.

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

Maximum number of listings to return.

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

Proxy settings. Irish residential proxies recommended for best results.

## Actor input object example

```json
{
  "searchQuery": "Dublin",
  "listingType": "sale",
  "propertyType": "all",
  "maxResults": 20,
  "proxyConfiguration": {
    "useApifyProxy": true,
    "apifyProxyGroups": [
      "RESIDENTIAL"
    ],
    "apifyProxyCountry": "IE"
  }
}
```

# 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 = {
    "searchQuery": "Dublin",
    "maxResults": 20,
    "proxyConfiguration": {
        "useApifyProxy": true,
        "apifyProxyGroups": [
            "RESIDENTIAL"
        ],
        "apifyProxyCountry": "IE"
    }
};

// Run the Actor and wait for it to finish
const run = await client.actor("studio-amba/daft-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 = {
    "searchQuery": "Dublin",
    "maxResults": 20,
    "proxyConfiguration": {
        "useApifyProxy": True,
        "apifyProxyGroups": ["RESIDENTIAL"],
        "apifyProxyCountry": "IE",
    },
}

# Run the Actor and wait for it to finish
run = client.actor("studio-amba/daft-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 '{
  "searchQuery": "Dublin",
  "maxResults": 20,
  "proxyConfiguration": {
    "useApifyProxy": true,
    "apifyProxyGroups": [
      "RESIDENTIAL"
    ],
    "apifyProxyCountry": "IE"
  }
}' |
apify call studio-amba/daft-scraper --silent --output-dataset

```

## MCP server setup

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

```

## OpenAPI specification

```json
{
    "openapi": "3.0.1",
    "info": {
        "title": "Daft.ie Scraper — Irish Real Estate Listings",
        "description": "Scrape real estate listings from Daft.ie — Ireland's largest property portal. Get prices, addresses, BER ratings, coordinates, photos, and agent info for properties for sale, rent, or sharing. No login or cookies required.",
        "version": "0.1",
        "x-build-id": "QwQoechzhhXeZHOwH"
    },
    "servers": [
        {
            "url": "https://api.apify.com/v2"
        }
    ],
    "paths": {
        "/acts/studio-amba~daft-scraper/run-sync-get-dataset-items": {
            "post": {
                "operationId": "run-sync-get-dataset-items-studio-amba-daft-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~daft-scraper/runs": {
            "post": {
                "operationId": "runs-sync-studio-amba-daft-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~daft-scraper/run-sync": {
            "post": {
                "operationId": "run-sync-studio-amba-daft-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": {
                    "searchQuery": {
                        "title": "Search Location",
                        "type": "string",
                        "description": "Location to search (e.g. 'Dublin', 'Cork City', 'Galway'). Maps to Daft.ie's location filter.",
                        "default": "Dublin"
                    },
                    "listingType": {
                        "title": "Listing Type",
                        "enum": [
                            "sale",
                            "rent",
                            "sharing"
                        ],
                        "type": "string",
                        "description": "Type of listing to search for.",
                        "default": "sale"
                    },
                    "propertyType": {
                        "title": "Property Type",
                        "enum": [
                            "all",
                            "houses",
                            "apartments",
                            "studios",
                            "duplexes",
                            "bungalows",
                            "detached",
                            "semi-detached",
                            "terraced",
                            "townhouses",
                            "sites"
                        ],
                        "type": "string",
                        "description": "Filter by property type.",
                        "default": "all"
                    },
                    "minPrice": {
                        "title": "Minimum Price (EUR)",
                        "minimum": 0,
                        "type": "integer",
                        "description": "Minimum price filter in EUR."
                    },
                    "maxPrice": {
                        "title": "Maximum Price (EUR)",
                        "minimum": 0,
                        "type": "integer",
                        "description": "Maximum price filter in EUR."
                    },
                    "minBeds": {
                        "title": "Minimum Bedrooms",
                        "minimum": 0,
                        "maximum": 10,
                        "type": "integer",
                        "description": "Minimum number of bedrooms."
                    },
                    "maxResults": {
                        "title": "Max Results",
                        "minimum": 1,
                        "maximum": 10000,
                        "type": "integer",
                        "description": "Maximum number of listings to return.",
                        "default": 100
                    },
                    "proxyConfiguration": {
                        "title": "Proxy Configuration",
                        "type": "object",
                        "description": "Proxy settings. Irish residential proxies recommended for best results."
                    }
                }
            },
            "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
                                    }
                                }
                            }
                        }
                    }
                }
            }
        }
    }
}
```
