# Aircraft24 Listings Scraper (`parseforge/aircraft24-scraper`) Actor

Browse Aircraft24 listings for planes and helicopters by category, manufacturer, or price. Each aircraft returns the model, manufacturer, year, total time in hours, price, dealer, registration, engine type, location, and gallery images. Built for aviation market research.

- **URL**: https://apify.com/parseforge/aircraft24-scraper.md
- **Developed by:** [ParseForge](https://apify.com/parseforge) (community)
- **Categories:** Developer tools, Automation, Other
- **Stats:** 2 total users, 1 monthly users, 100.0% runs succeeded, 0 bookmarks
- **User rating**: No ratings yet

## Pricing

from $5.88 / 1,000 results

This Actor is paid per event. You are not charged for the Apify platform usage, but only a fixed price for specific events.
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

![ParseForge Banner](https://github.com/ParseForge/apify-assets/blob/ad35ccc13ddd068b9d6cba33f323962e39aed5b2/banner.jpg?raw=true)

## ✈️ Aircraft24 Scraper

> 🚀 **Export Aircraft24 listings in seconds. Model, manufacturer, year, total airframe time, asking price, dealer, and gallery images in one clean dataset.**

> 🕒 **Last updated:** 2026-06-05 · **📊 13 fields** per listing · Europe-wide aircraft inventory · Single-engine to jets · Live aircraft24.com search results

The Aircraft24 Scraper turns any [aircraft24.com](https://www.aircraft24.com) search into a clean dataset. Pick a category, optionally filter by manufacturer or price band, and the actor walks every result page and flattens each aircraft listing into one row.

| 🎯 Target Audience | 💡 Primary Use Cases |
|---|---|
| 🛩️ Aircraft brokers | Monitor pan-European inventory in real time |
| 🏢 Charter operators | Source aircraft for fleet expansion |
| 📊 Aviation analysts | Build pricing trend datasets by model and year |
| 👨‍✈️ Private buyers | Compare hundreds of listings in a single sheet |
| 📰 Journalists | Track the used aircraft market |
| 👩‍💻 Developers | Mirror aircraft24 inventory into your app |

### 📋 What the Aircraft24 Scraper does

- Builds the Aircraft24 search URL from your category, manufacturer, and price band.
- Walks every result page until your `maxItems` cap or the end of results.
- Parses each card for model, year, price, location, dealer, and gallery images.
- Surfaces upstream errors as clean records rather than crashing.
- Emits records ready for download in tabular and structured formats.

> 💡 **Why it matters:** Aircraft24 is one of Europe's largest aircraft marketplaces but ships only paginated HTML. This actor flattens the catalog into one tidy dataset.

### 🎬 Full Demo

_🚧 Coming soon._

### ⚙️ Input

<table>
<tr><th>Field</th><th>Type</th><th>Required</th><th>Description</th></tr>
<tr><td><code>category</code></td><td>enum</td><td>No</td><td>all, single-engine-piston, jet, helicopter, etc.</td></tr>
<tr><td><code>maxItems</code></td><td>integer</td><td>No</td><td>Free 10, paid up to 1,000,000.</td></tr>
<tr><td><code>manufacturer</code></td><td>string</td><td>No</td><td>Cessna, Piper, Cirrus, etc.</td></tr>
<tr><td><code>minPrice</code></td><td>integer</td><td>No</td><td>Min price in EUR.</td></tr>
<tr><td><code>maxPrice</code></td><td>integer</td><td>No</td><td>Max price in EUR.</td></tr>
</table>

**Example 1, single-engine pistons under 150k EUR:**
```json
{ "category": "single-engine-piston", "maxPrice": 150000, "maxItems": 100 }
````

**Example 2, all Cessna listings:**

```json
{ "category": "all", "manufacturer": "Cessna", "maxItems": 50 }
```

> ⚠️ **Good to Know:** Aircraft24 listings are priced in EUR. The actor surfaces the raw numeric price as the dealer entered it.

### 📊 Output

| Field | Type | Description |
|---|---|---|
| ✈️ `model` | string | Aircraft model and headline. |
| 🏭 `manufacturer` | string | Manufacturer name. |
| 📅 `year` | number | Year of manufacture. |
| ⏱️ `ttaf_hours` | number | Total time airframe hours when shown. |
| 📍 `location` | string | Listing location. |
| 💵 `price_usd` | number | Asking price (raw numeric). |
| 🏢 `dealer` | string | Dealer or seller name. |
| 🔖 `registration` | string | Tail number when shown. |
| 🔧 `engine_type` | string | Engine description when shown. |
| 🖼️ `image_urls` | string\[] | Gallery image URLs. |
| 🔗 `url` | string | Listing URL. |
| 🕒 `scrapedAt` | string | ISO timestamp. |
| ❌ `error` | string | Set if upstream errored. |

### ✨ Why choose this Actor

| 🌍 | Pan-European inventory in one sweep. |
| 🧹 | Clean numeric price column ready for analysis. |
| 🛟 | Clean `error` record on upstream issues, never a crash. |
| 🏷️ | Filter by category, manufacturer, and price band. |
| 🖼️ | Gallery image URLs ready for downstream pipelines. |
| 💾 | Push to dataset, then download in tabular or structured formats. |

### 📈 How it compares to alternatives

| Approach | Setup time | Pagination | Numeric price |
|---|---|---|---|
| Manual copy-paste | Hours | Manual | Manual |
| Roll your own scraper | 4 hours plus | DIY | DIY |
| **This Actor** | 5 sec, no install | Automatic | Yes |

### 🚀 How to use

1. Click **Try for free**.
2. Pick a category and optionally a manufacturer.
3. Optionally clamp the price band.
4. Click **Start**. The dataset is ready in seconds.

### 💼 Business use cases

**🛩️ Broker dashboards.** Monitor inventory shifts daily across categories.

**📊 Pricing analytics.** Track average asking price by model and year.

**🏢 Charter sourcing.** Filter ready-to-buy candidates by category and budget.

**🤖 ML training.** Build aircraft-pricing models with real listing data.

### 🔌 Automating Aircraft24 Scraper

- **Make and Zapier**, push new listings to Slack or Airtable.
- **Cron schedule**, run nightly to catch new inventory.
- **Webhooks**, get a POST when the run finishes.
- **Pipe to BigQuery, Snowflake, or Postgres**, native Apify integrations move datasets straight into your warehouse.

### 🌟 Beyond business use cases

**🎓 Education.** Use real aircraft pricing data in aviation coursework.

**🧪 Personal research.** Hunt for your next plane without manual scrolling.

**🤝 Non-profit.** Track aviation market trends for advocacy work.

**🧰 Tinkering.** Prototype an aviation marketplace aggregator.

### 🤖 Ask an AI assistant about this scraper

Drop this README into ChatGPT, Claude, or any AI assistant and ask it to map your specific workflow to the actor's inputs.

### ❓ Frequently Asked Questions

**❓ Is this scraping or API?** HTML scraping of the public Aircraft24 search.

**❓ How fresh is the data?** As fresh as Aircraft24 serves it.

**❓ Are prices in EUR?** Yes, the column reflects the raw number on the listing.

**❓ Can I filter by manufacturer?** Yes, pass the name as a string.

**❓ Does it follow detail pages?** Card-level fields only by default.

**❓ How are errors handled?** Upstream errors become a clean record with `error` populated.

**❓ Will the schema change?** Card-level fields are stable. Detail fields may be added as the site exposes them.

**❓ Can I schedule runs?** Yes, use Apify's native scheduler or Make and Zapier.

**❓ What download formats are supported?** All formats Apify dataset export supports.

**❓ Is residential proxying used?** Yes, residential proxies are used for clean access.

### 🔌 Integrate with any app

Apify ships native integrations with Make, Zapier, Slack, Discord, Google Drive, Google Sheets, Gmail, Airbyte, Keboola, Telegram, GitHub, and any REST API or webhook endpoint.

### 🔗 Recommended Actors

| Actor | What it does |
|---|---|
| [ParseForge Trade-A-Plane Scraper](https://apify.com/parseforge) | US aircraft listings from trade-a-plane.com. |
| [ParseForge YachtWorld Scraper](https://apify.com/parseforge) | Global yacht listings. |
| [ParseForge OurAirports Scraper](https://apify.com/parseforge/ourairports-scraper) | Global airport database. |
| [ParseForge Alpha Vantage Scraper](https://apify.com/parseforge) | Public market data, FX, crypto, indicators. |

> 💡 **Pro Tip:** browse the complete [ParseForge collection](https://apify.com/parseforge) for 900+ production-grade scrapers across business intelligence, real estate, e-commerce, sports, finance, and public records.

***

**Disclaimer:** This actor scrapes only publicly available data. ParseForge is not affiliated with, endorsed by, or sponsored by any of the third-party services referenced. Users are responsible for complying with the target site's terms of service and applicable law. [Create a free account w/ $5 credit](https://console.apify.com/sign-up?fpr=vmoqkp).

# Actor input Schema

## `category` (type: `string`):

Category of aircraft to search on AirCraft24. Each maps to a dedicated search section on the site.

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

Maximum number of aircraft listings to collect. Free users are limited to 10 items (preview). Paid users up to 1,000,000.

## `manufacturer` (type: `string`):

Manufacturer or model text to filter by (e.g. Cessna, Piper, Robinson). Matched against the make/model of each listing. Leave empty for all.

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

Lower bound on the asking price in US dollars. Listings with no price (on request) may still be returned.

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

Upper bound on the asking price in US dollars.

## `orderBy` (type: `string`):

How to order the search results returned by AirCraft24.

## Actor input object example

```json
{
  "category": "single-engine-piston",
  "maxItems": 10,
  "orderBy": "AD_DATECREATED"
}
```

# Actor output Schema

## `results` (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 = {
    "maxItems": 10
};

// Run the Actor and wait for it to finish
const run = await client.actor("parseforge/aircraft24-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 = { "maxItems": 10 }

# Run the Actor and wait for it to finish
run = client.actor("parseforge/aircraft24-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 '{
  "maxItems": 10
}' |
apify call parseforge/aircraft24-scraper --silent --output-dataset

```

## MCP server setup

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

```

## OpenAPI specification

```json
{
    "openapi": "3.0.1",
    "info": {
        "title": "Aircraft24 Listings Scraper",
        "description": "Browse Aircraft24 listings for planes and helicopters by category, manufacturer, or price. Each aircraft returns the model, manufacturer, year, total time in hours, price, dealer, registration, engine type, location, and gallery images. Built for aviation market research.",
        "version": "0.1",
        "x-build-id": "wmO9VdrbNDfjQeUhj"
    },
    "servers": [
        {
            "url": "https://api.apify.com/v2"
        }
    ],
    "paths": {
        "/acts/parseforge~aircraft24-scraper/run-sync-get-dataset-items": {
            "post": {
                "operationId": "run-sync-get-dataset-items-parseforge-aircraft24-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/parseforge~aircraft24-scraper/runs": {
            "post": {
                "operationId": "runs-sync-parseforge-aircraft24-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/parseforge~aircraft24-scraper/run-sync": {
            "post": {
                "operationId": "run-sync-parseforge-aircraft24-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": {
                    "category": {
                        "title": "Aircraft category",
                        "enum": [
                            "single-engine-piston",
                            "multi-engine-piston",
                            "turboprop",
                            "jet",
                            "helicopter"
                        ],
                        "type": "string",
                        "description": "Category of aircraft to search on AirCraft24. Each maps to a dedicated search section on the site.",
                        "default": "single-engine-piston"
                    },
                    "maxItems": {
                        "title": "Max Items",
                        "minimum": 1,
                        "maximum": 1000000,
                        "type": "integer",
                        "description": "Maximum number of aircraft listings to collect. Free users are limited to 10 items (preview). Paid users up to 1,000,000."
                    },
                    "manufacturer": {
                        "title": "Manufacturer / model",
                        "type": "string",
                        "description": "Manufacturer or model text to filter by (e.g. Cessna, Piper, Robinson). Matched against the make/model of each listing. Leave empty for all."
                    },
                    "minPrice": {
                        "title": "Minimum price (USD)",
                        "minimum": 0,
                        "type": "integer",
                        "description": "Lower bound on the asking price in US dollars. Listings with no price (on request) may still be returned."
                    },
                    "maxPrice": {
                        "title": "Maximum price (USD)",
                        "minimum": 0,
                        "type": "integer",
                        "description": "Upper bound on the asking price in US dollars."
                    },
                    "orderBy": {
                        "title": "Sort order",
                        "enum": [
                            "AD_DATECREATED",
                            "AD_PRICEEUR",
                            "AD_SEARCHSTRING",
                            "AD_YEARBUILT"
                        ],
                        "type": "string",
                        "description": "How to order the search results returned by AirCraft24.",
                        "default": "AD_DATECREATED"
                    }
                }
            },
            "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
                                    }
                                }
                            }
                        }
                    }
                }
            }
        }
    }
}
```
