# Mobile.de Scraper — German Car Listings, Prices & Dealer Data (`studio-amba/mobile-de-scraper`) Actor

Scrape car listings from Mobile.de, Germany's #1 car marketplace with 46M+ monthly visits. Search by keyword, make, model, price range, and more. Extract prices, mileage, specs, dealer info, and photos. No login or cookies required.

- **URL**: https://apify.com/studio-amba/mobile-de-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

## Mobile.de Scraper

Scrape **car listings from [Mobile.de](https://www.mobile.de)**, Germany's largest online car marketplace with over 46 million monthly visits. Extract prices, specifications, mileage, dealer information, and photos from millions of car listings. No login or cookies required.

### What does Mobile.de Scraper do?

This Actor extracts structured car listing data from Mobile.de search results. Search by keyword, filter by price, year, and mileage, and get clean, structured JSON output with all the details you need for market research, price comparison, or inventory monitoring.

Mobile.de is part of the Adevinta group and hosts listings from both private sellers and professional dealers across Germany and Europe. With this scraper, you can programmatically access this data via the Apify platform with built-in proxy rotation, scheduling, and API access.

### Why use Mobile.de Scraper?

- **Market research** — Track car prices across makes, models, and regions in Germany's largest car market
- **Dealer intelligence** — Monitor competitor inventory and pricing strategies
- **Price comparison** — Find the best deals by comparing thousands of listings automatically
- **Inventory monitoring** — Set up scheduled runs to track new listings matching your criteria
- **Data analysis** — Export to CSV, JSON, or Excel for analysis in your tools of choice

### How to scrape Mobile.de

1. Go to the **Input** tab
2. Enter a search query (e.g., "bmw 3er") or provide direct Mobile.de URLs
3. Optionally set price, year, and mileage filters
4. Set the maximum number of results you want
5. Click **Start** and wait for the run to finish
6. Download your data from the **Output** tab in JSON, CSV, or Excel format

### Input

| Field | Type | Required | Description |
|-------|------|----------|-------------|
| `query` | String | No | Search term (e.g., "bmw", "audi a4") |
| `startUrls` | Array | No | Direct Mobile.de search or detail URLs |
| `minPrice` | Integer | No | Minimum price filter in EUR |
| `maxPrice` | Integer | No | Maximum price filter in EUR |
| `minYear` | Integer | No | Minimum first registration year |
| `maxMileage` | Integer | No | Maximum mileage in km |
| `maxResults` | Integer | No | Maximum listings to scrape (default: 100) |
| `proxyConfiguration` | Object | No | Proxy settings (residential recommended) |

### Output

Each car listing contains:

| Field | Type | Example |
|-------|------|---------|
| `make` | String | `"BMW"` |
| `model` | String | `"3er"` |
| `variant` | String | `"320d Touring M Sport"` |
| `title` | String | `"BMW 320d Touring M Sport"` |
| `price` | Number | `32900` |
| `currency` | String | `"EUR"` |
| `year` | Number | `2021` |
| `mileage` | Number | `45000` |
| `fuelType` | String | `"Diesel"` |
| `transmission` | String | `"Automatik"` |
| `power` | String | `"190 PS"` |
| `sellerType` | String | `"Dealer"` |
| `sellerName` | String | `"Autohaus Schmidt GmbH"` |
| `location` | String | `"Munich, Bavaria"` |
| `imageUrl` | String | Main listing image URL |
| `imageUrls` | Array | All listing image URLs |
| `url` | String | Direct link to the listing |
| `scrapedAt` | String | `"2026-04-06T12:00:00.000Z"` |

### Example output

```json
{
    "make": "BMW",
    "model": "3er",
    "variant": "320d Touring M Sport",
    "title": "BMW 320d Touring M Sport",
    "price": 32900,
    "currency": "EUR",
    "year": 2021,
    "mileage": 45000,
    "fuelType": "Diesel",
    "transmission": "Automatik",
    "power": "190 PS",
    "sellerType": "Dealer",
    "sellerName": "Autohaus Schmidt GmbH",
    "location": "Munich, Bavaria",
    "imageUrl": "https://img.classistatic.de/api/v1/mo-prod/images/...",
    "imageUrls": ["https://img.classistatic.de/api/v1/mo-prod/images/..."],
    "url": "https://suchen.mobile.de/fahrzeuge/details.html?id=123456789",
    "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 Mobile.de?

This Actor uses a browser-based crawler (Playwright) with residential proxies due to Mobile.de's Akamai bot protection. Estimated cost:

- **~0.5 compute units per 100 results** with residential proxy
- At standard Apify pricing, that's roughly **$2.50 per 1,000 car listings**

The cost depends on the number of pages scraped and proxy usage. Using the `maxResults` parameter helps control costs.

### Tips for best results

- **Use residential proxies** — Mobile.de uses Akamai bot protection. Residential proxies are strongly recommended for reliable scraping
- **Start small** — Test with `maxResults: 10` before running large scrapes
- **Use filters** — Price, year, and mileage filters reduce the number of pages to scrape
- **Schedule runs** — Set up daily or weekly runs to track price changes over time
- **Direct URLs** — If you know the exact search URL from Mobile.de, paste it in `startUrls` for precise control

### Limitations

- Residential proxies are required due to Akamai bot protection
- Mobile.de may rate-limit aggressive scraping; the actor uses low concurrency by default
- Some listing details (full description, all specs) require visiting detail pages, which increases cost
- Data is scraped from the public website and may change without notice

### FAQ and support

**Is it legal to scrape Mobile.de?** This Actor extracts publicly available data from Mobile.de. Always respect the website's terms of service and applicable laws in your jurisdiction.

**The scraper returns no results.** Make sure you are using residential proxies. Mobile.de's Akamai protection blocks datacenter IPs.

**Can I scrape specific car makes or models?** Yes, use the `query` field or provide a filtered Mobile.de search URL in `startUrls`.

For bug reports or feature requests, please use the **Issues** tab. For custom scraping solutions, feel free to reach out.

# Actor input Schema

## `query` (type: `string`):

Search term (e.g. 'bmw', 'audi a4', 'mercedes c-klasse'). Leave empty to browse all listings.

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

Direct Mobile.de search or detail URLs. Overrides the query field if provided.

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

Minimum price filter in euros.

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

Maximum price filter in euros.

## `minYear` (type: `integer`):

Minimum first registration year (e.g. 2018).

## `maxMileage` (type: `integer`):

Maximum mileage filter in kilometers.

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

Maximum number of car listings to scrape. Each search page has ~20 results.

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

Proxy settings. Residential proxies are REQUIRED for Mobile.de (Akamai bot protection).

## Actor input object example

```json
{
  "query": "bmw",
  "maxResults": 100
}
```

# 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 = {
    "query": "bmw"
};

// Run the Actor and wait for it to finish
const run = await client.actor("studio-amba/mobile-de-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 = { "query": "bmw" }

# Run the Actor and wait for it to finish
run = client.actor("studio-amba/mobile-de-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 '{
  "query": "bmw"
}' |
apify call studio-amba/mobile-de-scraper --silent --output-dataset

```

## MCP server setup

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

```

## OpenAPI specification

```json
{
    "openapi": "3.0.1",
    "info": {
        "title": "Mobile.de Scraper — German Car Listings, Prices & Dealer Data",
        "description": "Scrape car listings from Mobile.de, Germany's #1 car marketplace with 46M+ monthly visits. Search by keyword, make, model, price range, and more. Extract prices, mileage, specs, dealer info, and photos. No login or cookies required.",
        "version": "0.1",
        "x-build-id": "QYiknyYFu2CiDRAe0"
    },
    "servers": [
        {
            "url": "https://api.apify.com/v2"
        }
    ],
    "paths": {
        "/acts/studio-amba~mobile-de-scraper/run-sync-get-dataset-items": {
            "post": {
                "operationId": "run-sync-get-dataset-items-studio-amba-mobile-de-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~mobile-de-scraper/runs": {
            "post": {
                "operationId": "runs-sync-studio-amba-mobile-de-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~mobile-de-scraper/run-sync": {
            "post": {
                "operationId": "run-sync-studio-amba-mobile-de-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": {
                    "query": {
                        "title": "Search Query",
                        "type": "string",
                        "description": "Search term (e.g. 'bmw', 'audi a4', 'mercedes c-klasse'). Leave empty to browse all listings."
                    },
                    "startUrls": {
                        "title": "Start URLs",
                        "type": "array",
                        "description": "Direct Mobile.de search or detail URLs. Overrides the query field if provided.",
                        "items": {
                            "type": "object",
                            "required": [
                                "url"
                            ],
                            "properties": {
                                "url": {
                                    "type": "string",
                                    "title": "URL of a web page",
                                    "format": "uri"
                                }
                            }
                        }
                    },
                    "minPrice": {
                        "title": "Minimum Price (EUR)",
                        "minimum": 0,
                        "type": "integer",
                        "description": "Minimum price filter in euros."
                    },
                    "maxPrice": {
                        "title": "Maximum Price (EUR)",
                        "minimum": 0,
                        "type": "integer",
                        "description": "Maximum price filter in euros."
                    },
                    "minYear": {
                        "title": "Minimum Year",
                        "minimum": 1900,
                        "type": "integer",
                        "description": "Minimum first registration year (e.g. 2018)."
                    },
                    "maxMileage": {
                        "title": "Maximum Mileage (km)",
                        "minimum": 0,
                        "type": "integer",
                        "description": "Maximum mileage filter in kilometers."
                    },
                    "maxResults": {
                        "title": "Max Results",
                        "minimum": 1,
                        "maximum": 10000,
                        "type": "integer",
                        "description": "Maximum number of car listings to scrape. Each search page has ~20 results.",
                        "default": 100
                    },
                    "proxyConfiguration": {
                        "title": "Proxy Configuration",
                        "type": "object",
                        "description": "Proxy settings. Residential proxies are REQUIRED for Mobile.de (Akamai bot protection)."
                    }
                }
            },
            "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
                                    }
                                }
                            }
                        }
                    }
                }
            }
        }
    }
}
```
