# Akakce Scraper - Turkish Price Comparison Data (`studio-amba/akakce-scraper`) Actor

Scrape product prices and merchant offers from Akakce.com, Turkey's largest price comparison site with 20M+ monthly visits. Compare prices across hundreds of Turkish retailers. Extract product names, price ranges, merchant lists, ratings, and more. No login required.

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

## Akakce Scraper

Scrape product prices, merchant offers, and comparison data from Akakce.com — Turkey's largest price comparison engine with 20M+ monthly visits, aggregating prices from hundreds of Turkish online retailers.

### How to scrape Akakce data

Akakce is Turkey's leading price comparison platform, aggregating product prices from hundreds of online retailers. This actor lets you extract structured product and pricing data from Akakce search results, category pages, and individual product pages without any login or cookies.

1. Go to the actor's input page.
2. Enter a search query (e.g., "laptop", "iPhone 16", "kulaklık") or provide a category URL.
3. Set the maximum number of results you want.
4. Optionally enable "Include Merchant Offers" to get all individual store prices for each product.
5. Click "Start" and wait for the run to finish.
6. Download your data in JSON, CSV, or Excel format.

The actor searches Akakce just like a regular user would, extracts product data from search results and product pages, and returns clean, structured data ready for analysis.

### Features

- Search by keyword across all Akakce product categories
- Browse specific category pages for targeted scraping
- Extract lowest and highest prices across all merchants
- Get individual merchant offers with store names, prices, and links
- Extract brands, ratings, review counts, and number of offers
- Automatic pagination to collect large result sets
- Multi-strategy extraction: JSON-LD structured data and DOM fallback
- No cookies or login required
- Residential proxy support for reliable access with Turkish IP

### Input options

| Field | Type | Description | Default |
|-------|------|-------------|---------|
| `searchQuery` | String | Product search term (e.g., "laptop", "kulaklık") | `"laptop"` |
| `categoryUrl` | String | Optional Akakce category URL to scrape directly | — |
| `maxResults` | Integer | Maximum number of products to return (1–10,000) | `100` |
| `includeOffers` | Boolean | Visit product pages to extract all merchant offers | `false` |
| `proxyConfiguration` | Object | Proxy settings — Turkish residential proxies recommended | TR residential |

#### Example input

```json
{
    "searchQuery": "laptop",
    "maxResults": 50,
    "proxyConfiguration": {
        "useApifyProxy": true,
        "apifyProxyGroups": ["RESIDENTIAL"],
        "apifyProxyCountry": "TR"
    }
}
````

#### Scraping a specific category

You can also scrape a specific Akakce category page by providing the `categoryUrl` instead of a search query:

```json
{
    "categoryUrl": "https://www.akakce.com/laptop-notebook.html",
    "maxResults": 200
}
```

#### Getting merchant offers

Enable `includeOffers` to visit each product page and extract all individual merchant prices. This is slower but gives you full price comparison data:

```json
{
    "searchQuery": "iPhone 16",
    "includeOffers": true,
    "maxResults": 20
}
```

### Output fields

| Field | Type | Description |
|-------|------|-------------|
| `productName` | String | Full product name |
| `category` | String | Product category from Akakce |
| `lowestPrice` | Number | Lowest price across all merchants (TRY) |
| `highestPrice` | Number | Highest price across all merchants (TRY) |
| `currency` | String | Currency code (TRY) |
| `numberOfOffers` | Integer | Number of merchants with this product |
| `brand` | String | Brand or manufacturer |
| `imageUrl` | String | Product image URL |
| `url` | String | Full Akakce product page URL |
| `merchants` | Array | Individual merchant offers (when `includeOffers` is enabled) |
| `rating` | Number | Average product rating (0–5 scale) |
| `reviewCount` | Integer | Number of user reviews |
| `scrapedAt` | String | ISO 8601 timestamp of when the data was collected |

#### Merchant offer fields

When `includeOffers` is enabled, each item in the `merchants` array contains:

| Field | Type | Description |
|-------|------|-------------|
| `merchantName` | String | Store/retailer name |
| `price` | Number | Price offered by this merchant (TRY) |
| `merchantUrl` | String | Link to the product on the merchant's site |

### Example output

```json
{
    "productName": "Apple MacBook Air M4 16 GB 256 GB SSD 13.6\"",
    "category": "Laptop Notebook",
    "lowestPrice": 42999,
    "highestPrice": 52490,
    "currency": "TRY",
    "numberOfOffers": 15,
    "brand": "Apple",
    "imageUrl": "https://cdn.akakce.com/apple/apple-macbook-air-m4.jpg",
    "url": "https://www.akakce.com/apple-macbook-air-m4-16gb-256gb.html",
    "merchants": [
        {
            "merchantName": "Hepsiburada",
            "price": 42999,
            "merchantUrl": "https://www.akakce.com/r.php?..."
        },
        {
            "merchantName": "Trendyol",
            "price": 43500,
            "merchantUrl": "https://www.akakce.com/r.php?..."
        },
        {
            "merchantName": "Amazon TR",
            "price": 44990,
            "merchantUrl": "https://www.akakce.com/r.php?..."
        }
    ],
    "rating": 4.7,
    "reviewCount": 128,
    "scrapedAt": "2026-06-09T14:30:00.000Z"
}
```

### Cost estimate

The actor uses PlaywrightCrawler (headless browser) for reliable rendering of Akakce pages.

- \~100 results (listing only): approximately $0.05–0.15 in platform costs
- \~100 results (with merchant offers): approximately $0.20–0.50 in platform costs
- \~1,000 results: approximately $0.50–2.00 depending on `includeOffers`
- Residential proxy usage adds to the cost depending on data transfer

For most use cases, a single run costs well under $1.00.

### Limitations

- Akakce may rate-limit aggressive scraping — use Turkish residential proxies for best results.
- Product availability and pricing data reflects what Akakce shows at the time of scraping. Prices change frequently.
- Very broad search queries may return many results across categories. Use specific queries or category URLs for focused data.
- The HTML structure of Akakce may change without notice, which could temporarily affect data extraction.
- Merchant offer extraction requires visiting individual product pages, which is slower than listing-only mode.

### Tips for best results

- **Use specific queries** — "Samsung Galaxy S25 Ultra" works better than "telefon"
- **Use category URLs** — for comprehensive category scraping, provide the category URL directly
- **Use Turkish proxies** — Turkish residential proxies give the most reliable results
- **Start small** — test with `maxResults: 10` before running large scrapes
- **Enable merchant offers selectively** — only use `includeOffers: true` when you need individual store prices

### Use cases

- **Price monitoring** — track product prices across Turkish online retailers
- **Competitive analysis** — compare your prices against marketplace aggregated data
- **Market research** — analyze product availability and pricing trends in the Turkish market
- **Price intelligence** — get the full price spread from cheapest to most expensive merchant
- **Retail analytics** — monitor which merchants carry which products and at what prices
- **Data enrichment** — enhance product databases with up-to-date Turkish pricing

# Actor input Schema

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

Search term to find products on Akakce (e.g., 'laptop', 'iPhone 16', 'kulaklık'). If empty, defaults to 'laptop'.

## `categoryUrl` (type: `string`):

Optional: an Akakce category page URL to scrape instead of searching. Example: https://www.akakce.com/laptop-notebook.html

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

Maximum number of products to return.

## `includeOffers` (type: `boolean`):

When enabled, visits each product detail page to extract all individual merchant offers (name, price, URL). Slower but gives full price comparison data.

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

Proxy settings. Residential proxies with Turkish IP are recommended for best results.

## Actor input object example

```json
{
  "searchQuery": "laptop",
  "maxResults": 100,
  "includeOffers": false,
  "proxyConfiguration": {
    "useApifyProxy": true,
    "apifyProxyGroups": [
      "RESIDENTIAL"
    ],
    "apifyProxyCountry": "TR"
  }
}
```

# 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": "laptop",
    "proxyConfiguration": {
        "useApifyProxy": true,
        "apifyProxyGroups": [
            "RESIDENTIAL"
        ],
        "apifyProxyCountry": "TR"
    }
};

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

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

```

## MCP server setup

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

```

## OpenAPI specification

```json
{
    "openapi": "3.0.1",
    "info": {
        "title": "Akakce Scraper - Turkish Price Comparison Data",
        "description": "Scrape product prices and merchant offers from Akakce.com, Turkey's largest price comparison site with 20M+ monthly visits. Compare prices across hundreds of Turkish retailers. Extract product names, price ranges, merchant lists, ratings, and more. No login required.",
        "version": "0.1",
        "x-build-id": "SCBBI0sARI3Y6CmiN"
    },
    "servers": [
        {
            "url": "https://api.apify.com/v2"
        }
    ],
    "paths": {
        "/acts/studio-amba~akakce-scraper/run-sync-get-dataset-items": {
            "post": {
                "operationId": "run-sync-get-dataset-items-studio-amba-akakce-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~akakce-scraper/runs": {
            "post": {
                "operationId": "runs-sync-studio-amba-akakce-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~akakce-scraper/run-sync": {
            "post": {
                "operationId": "run-sync-studio-amba-akakce-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 Query",
                        "type": "string",
                        "description": "Search term to find products on Akakce (e.g., 'laptop', 'iPhone 16', 'kulaklık'). If empty, defaults to 'laptop'."
                    },
                    "categoryUrl": {
                        "title": "Category URL",
                        "type": "string",
                        "description": "Optional: an Akakce category page URL to scrape instead of searching. Example: https://www.akakce.com/laptop-notebook.html"
                    },
                    "maxResults": {
                        "title": "Max Results",
                        "minimum": 1,
                        "maximum": 10000,
                        "type": "integer",
                        "description": "Maximum number of products to return.",
                        "default": 100
                    },
                    "includeOffers": {
                        "title": "Include Merchant Offers",
                        "type": "boolean",
                        "description": "When enabled, visits each product detail page to extract all individual merchant offers (name, price, URL). Slower but gives full price comparison data.",
                        "default": false
                    },
                    "proxyConfiguration": {
                        "title": "Proxy Configuration",
                        "type": "object",
                        "description": "Proxy settings. Residential proxies with Turkish IP are 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
                                    }
                                }
                            }
                        }
                    }
                }
            }
        }
    }
}
```
