# Noon.com Scraper - Products & Food Delivery (`thirdwatch/noon-scraper`) Actor

Scrape products from Noon.com AND restaurants/menus from food.noon.com. Products: prices, ratings, sellers, brands, discounts. Food: restaurants, cuisines, delivery times, full menus. UAE, Saudi Arabia, Egypt. No login needed.

- **URL**: https://apify.com/thirdwatch/noon-scraper.md
- **Developed by:** [Thirdwatch](https://apify.com/thirdwatch) (community)
- **Categories:** E-commerce, Automation
- **Stats:** 21 total users, 8 monthly users, 96.6% runs succeeded, 0 bookmarks
- **User rating**: No ratings yet

## Pricing

from $1.20 / 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

## Noon.com Scraper

> Scrape products from Noon.com — the leading Middle East e-commerce platform across UAE, Saudi Arabia, and Egypt.

### What you get

Search Noon.com by keyword and extract structured product data: titles, sale and original prices, discount labels, ratings, sellers, and brands. Supports all three Noon country sites with automatic currency detection (AED, SAR, EGP). Optional detail scraping adds full descriptions, highlights, and specifications.

### Output fields

| Field | Description |
|-------|-------------|
| `title` | Product name |
| `price` | Current selling price (numeric) |
| `original_price` | Price before discount (numeric) |
| `currency` | Currency code: AED, SAR, or EGP |
| `discount` | Discount label (e.g., "30% OFF") |
| `rating` | Product rating (out of 5) |
| `rating_count` | Number of ratings |
| `seller` | Seller or fulfillment info |
| `brand` | Product brand |
| `url` | Full product page URL |
| `image_url` | Product image URL |
| `country` | Country code (`uae-en`, `sa-en`, `eg-en`) |
| `query` | Search query that surfaced this product |
| `scraped_at` | Timestamp |

When `scrapeDetails` is enabled, each product also includes:

| Field | Description |
|-------|-------------|
| `description` | Full product description |
| `highlights` | Product highlights / bullet points |
| `specifications` | Key-value pairs of product specs |

### Example output

```json
{
    "title": "Apple MacBook Air 13-inch M3 chip 8GB 256GB SSD",
    "price": 4299.0,
    "original_price": 4999.0,
    "currency": "AED",
    "discount": "14% OFF",
    "rating": 4.8,
    "rating_count": 342,
    "seller": "noon",
    "brand": "Apple",
    "url": "https://www.noon.com/uae-en/apple-macbook-air-13-inch-m3/N12345678/p/",
    "image_url": "https://f.nooncdn.com/p/v1234/N12345678.jpg",
    "country": "uae-en",
    "query": "macbook",
    "scraped_at": "2026-04-11T12:00:00+00:00"
}
````

### Input parameters

| Parameter | Required | Description |
|-----------|----------|-------------|
| `mode` | No | `products` for noon.com e-commerce, `food` for food.noon.com. Default `products`. |
| `queries` | Yes | Search terms (e.g., `["laptop", "iphone 15"]`). |
| `country` | No | One of `uae-en`, `sa-en`, `eg-en`. Default `uae-en`. |
| `maxResults` | No | Maximum results across all queries. Default `20`, max `1000`. |
| `scrapeDetails` | No | Visit each product page to extract highlights and specs (products mode only). Default `false`. |
| `scrapeMenu` | No | Visit each restaurant's outlet page for full menu items (food mode only). Default `false`. |
| `proxyConfiguration` | No | Proxy settings. Defaults work out of the box. |

### Supported countries

| Country | Code | Currency |
|---------|------|----------|
| UAE | `uae-en` | AED |
| Saudi Arabia | `sa-en` | SAR |
| Egypt | `eg-en` | EGP |

### Use cases

- **E-commerce teams**: Monitor competitor pricing across the Middle East GCC markets.
- **Price trackers**: Build MENA price comparison dashboards (AED, SAR, EGP).
- **Brand managers**: Track which sellers list your brand on Noon and at what price.
- **Market researchers**: Analyze category density, discount depth, and rating distribution.

### Pricing

Pay-per-result pricing. Tiered discounts apply automatically based on usage volume.

| Tier | Price per result |
|------|------------------|
| FREE | $0.002 |
| BRONZE | $0.0018 |
| SILVER | $0.0015 |
| GOLD | $0.0012 |

### Limitations

- Some products lack rating or discount data (no shoppers have rated them yet).
- Detail scraping visits each product page and is noticeably slower than listings-only mode.
- Product availability and prices differ between UAE, Saudi Arabia, and Egypt even for identical SKUs.
- Arabic product titles are returned via the English URL slugs (`uae-en`, `sa-en`, `eg-en`) — the Arabic site variants are not covered.

### Compared to alternatives

- **vs. regional MENA scrapers** (typically $0.005-0.01/result): This actor runs at $0.002/result on FREE and drops to $0.0012 on GOLD — 2-8x cheaper.
- **vs. Noon Partner API**: Noon's seller API is restricted to registered merchants and only exposes your own catalog. This actor is the public-data alternative.

Pairs well with [Amazon Scraper](https://apify.com/thirdwatch/amazon-product-scraper?fpr=9m2cd6) (compare vs. Amazon.ae) and [Noon Food Scraper](https://apify.com/thirdwatch/noon-food-scraper?fpr=9m2cd6) for food delivery.

### FAQ

**Which countries are supported?**
UAE, Saudi Arabia, and Egypt — the three Noon country sites.

**Do I need a Noon account?**
No. Only publicly visible search results are scraped.

**What's the difference between `mode: products` and `mode: food`?**
`products` covers noon.com (electronics, fashion, groceries). `food` covers food.noon.com (restaurants and menus). For food delivery specifically, use the dedicated [Noon Food Scraper](https://apify.com/thirdwatch/noon-food-scraper?fpr=9m2cd6).

**Should I enable `scrapeDetails`?**
Only if you need descriptions and specifications. It visits each product page and materially increases run time and cost.

Last verified: 2026-04

More scrapers at [thirdwatch.dev](https://thirdwatch.dev).

# Actor input Schema

## `mode` (type: `string`):

Scraping mode: 'products' for noon.com e-commerce, 'food' for food.noon.com restaurants and menus.

## `queries` (type: `array`):

Search queries. For products: 'laptop', 'iphone 15'. For food: 'pizza', 'burger', 'Downtown' (zone name), 'Indian' (cuisine). Leave empty in products mode to browse a category landing page directly.

## `country` (type: `string`):

Which Noon.com country to search.

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

Top-level Noon products category. When 'all' (default), no category filter is applied. With a query, the category words are prepended to the search; without a query, the category landing page is browsed directly.

## `subcategorySlug` (type: `string`):

Optional Noon subcategory URL slug appended to the category path (e.g. 'mobiles/smartphones'). Only used when category != 'all' and no query is provided. Leave blank to browse the top-level category landing page.

## `sortBy` (type: `string`):

Sort order for products listing.

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

Optional minimum price filter, in the country's local currency (AED / SAR / EGP).

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

Optional maximum price filter, in the country's local currency (AED / SAR / EGP).

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

Maximum number of results to scrape in total across all queries.

## `scrapeDetails` (type: `boolean`):

Visit individual product pages to extract highlights and specifications. Only used in 'products' mode. Slower but more data.

## `scrapeMenu` (type: `boolean`):

Visit each restaurant's outlet page to extract full menu items with prices. Only used in 'food' mode. Slower but more data.

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

Proxy settings. Leave default for best results.

## Actor input object example

```json
{
  "mode": "products",
  "queries": [
    "laptop"
  ],
  "country": "uae-en",
  "category": "all",
  "sortBy": "relevance",
  "maxResults": 20,
  "scrapeDetails": false,
  "scrapeMenu": false,
  "proxyConfiguration": {
    "useApifyProxy": true,
    "apifyProxyGroups": [
      "RESIDENTIAL"
    ]
  }
}
```

# 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 = {
    "mode": "products",
    "queries": [
        "laptop"
    ],
    "country": "uae-en",
    "category": "all",
    "sortBy": "relevance",
    "maxResults": 20
};

// Run the Actor and wait for it to finish
const run = await client.actor("thirdwatch/noon-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 = {
    "mode": "products",
    "queries": ["laptop"],
    "country": "uae-en",
    "category": "all",
    "sortBy": "relevance",
    "maxResults": 20,
}

# Run the Actor and wait for it to finish
run = client.actor("thirdwatch/noon-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 '{
  "mode": "products",
  "queries": [
    "laptop"
  ],
  "country": "uae-en",
  "category": "all",
  "sortBy": "relevance",
  "maxResults": 20
}' |
apify call thirdwatch/noon-scraper --silent --output-dataset

```

## MCP server setup

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

```

## OpenAPI specification

```json
{
    "openapi": "3.0.1",
    "info": {
        "title": "Noon.com Scraper - Products & Food Delivery",
        "description": "Scrape products from Noon.com AND restaurants/menus from food.noon.com. Products: prices, ratings, sellers, brands, discounts. Food: restaurants, cuisines, delivery times, full menus. UAE, Saudi Arabia, Egypt. No login needed.",
        "version": "1.0",
        "x-build-id": "emDez6ANcxe1sFlZ5"
    },
    "servers": [
        {
            "url": "https://api.apify.com/v2"
        }
    ],
    "paths": {
        "/acts/thirdwatch~noon-scraper/run-sync-get-dataset-items": {
            "post": {
                "operationId": "run-sync-get-dataset-items-thirdwatch-noon-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/thirdwatch~noon-scraper/runs": {
            "post": {
                "operationId": "runs-sync-thirdwatch-noon-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/thirdwatch~noon-scraper/run-sync": {
            "post": {
                "operationId": "run-sync-thirdwatch-noon-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": {
                    "mode": {
                        "title": "Mode",
                        "enum": [
                            "products",
                            "food"
                        ],
                        "type": "string",
                        "description": "Scraping mode: 'products' for noon.com e-commerce, 'food' for food.noon.com restaurants and menus.",
                        "default": "products"
                    },
                    "queries": {
                        "title": "Search Queries",
                        "type": "array",
                        "description": "Search queries. For products: 'laptop', 'iphone 15'. For food: 'pizza', 'burger', 'Downtown' (zone name), 'Indian' (cuisine). Leave empty in products mode to browse a category landing page directly.",
                        "default": [],
                        "items": {
                            "type": "string"
                        }
                    },
                    "country": {
                        "title": "Country",
                        "enum": [
                            "uae-en",
                            "sa-en",
                            "eg-en"
                        ],
                        "type": "string",
                        "description": "Which Noon.com country to search.",
                        "default": "uae-en"
                    },
                    "category": {
                        "title": "Category (Products mode)",
                        "enum": [
                            "all",
                            "electronics",
                            "mobiles",
                            "laptops",
                            "tvs",
                            "appliances",
                            "home-kitchen",
                            "fashion",
                            "beauty",
                            "baby-products",
                            "toys",
                            "sports-outdoors",
                            "health-wellness",
                            "groceries",
                            "pet-supplies",
                            "automotive",
                            "tools-home-improvement",
                            "gaming"
                        ],
                        "type": "string",
                        "description": "Top-level Noon products category. When 'all' (default), no category filter is applied. With a query, the category words are prepended to the search; without a query, the category landing page is browsed directly.",
                        "default": "all"
                    },
                    "subcategorySlug": {
                        "title": "Subcategory Slug (optional, Products mode)",
                        "type": "string",
                        "description": "Optional Noon subcategory URL slug appended to the category path (e.g. 'mobiles/smartphones'). Only used when category != 'all' and no query is provided. Leave blank to browse the top-level category landing page."
                    },
                    "sortBy": {
                        "title": "Sort By (Products mode)",
                        "enum": [
                            "relevance",
                            "popularity",
                            "priceAsc",
                            "priceDesc",
                            "newest",
                            "rating"
                        ],
                        "type": "string",
                        "description": "Sort order for products listing.",
                        "default": "relevance"
                    },
                    "minPrice": {
                        "title": "Min Price (Products mode)",
                        "minimum": 0,
                        "type": "integer",
                        "description": "Optional minimum price filter, in the country's local currency (AED / SAR / EGP)."
                    },
                    "maxPrice": {
                        "title": "Max Price (Products mode)",
                        "minimum": 0,
                        "type": "integer",
                        "description": "Optional maximum price filter, in the country's local currency (AED / SAR / EGP)."
                    },
                    "maxResults": {
                        "title": "Max Results",
                        "minimum": 1,
                        "maximum": 1000,
                        "type": "integer",
                        "description": "Maximum number of results to scrape in total across all queries.",
                        "default": 20
                    },
                    "scrapeDetails": {
                        "title": "Scrape Product Details",
                        "type": "boolean",
                        "description": "Visit individual product pages to extract highlights and specifications. Only used in 'products' mode. Slower but more data.",
                        "default": false
                    },
                    "scrapeMenu": {
                        "title": "Scrape Restaurant Menus",
                        "type": "boolean",
                        "description": "Visit each restaurant's outlet page to extract full menu items with prices. Only used in 'food' mode. Slower but more data.",
                        "default": false
                    },
                    "proxyConfiguration": {
                        "title": "Proxy Configuration",
                        "type": "object",
                        "description": "Proxy settings. Leave default for best results.",
                        "default": {
                            "useApifyProxy": true,
                            "apifyProxyGroups": [
                                "RESIDENTIAL"
                            ]
                        }
                    }
                }
            },
            "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
                                    }
                                }
                            }
                        }
                    }
                }
            }
        }
    }
}
```
