VOOZH about

URL: https://apify.com/automation-lab/zomato-restaurant-search-scraper

โ‡ฑ Zomato Restaurant Search Scraper & Restaurant Leads ยท Apify


Pricing

Pay per event

Go to Apify Store

Zomato Restaurant Search Scraper

Extract public Zomato restaurant leads with ratings, cuisines, review counts, locality, cost-for-two, images, and profile URLs.

Pricing

Pay per event

Rating

0.0

(0)

Developer

๐Ÿ‘ Stas Persiianenko

Stas Persiianenko

Maintained by Community

Actor stats

0

Bookmarked

2

Total users

1

Monthly active users

3 days ago

Last modified

Categories

Share

Extract restaurant leads from public Zomato city, restaurant, and cuisine pages. The actor returns Zomato profile URLs, names, cuisines, ratings, review counts, locality, address, cost-for-two, images, and source-page metadata in a clean dataset.

Use it when you need repeatable Zomato restaurant discovery for food-tech research, local business lead generation, restaurant sales outreach, local SEO work, or market mapping in Indian cities where Zomato has strong coverage.

What does Zomato Restaurant Search Scraper do?

Zomato Restaurant Search Scraper reads public Zomato pages and extracts restaurant cards from the embedded page state.

It can start from a city page such as https://www.zomato.com/bangalore/restaurants or a cuisine page such as https://www.zomato.com/bangalore/restaurants/biryani.

When enabled, it also follows public cuisine and locality links that Zomato exposes on the page so you can collect more restaurants from one city URL without using private APIs.

Who is it for?

  • ๐Ÿฝ๏ธ Restaurant sales teams building Zomato-based prospect lists.
  • ๐Ÿ“ Local SEO agencies checking restaurant categories, ratings, and profiles.
  • ๐Ÿงพ Food-tech analysts mapping cuisines, costs, and locations by city.
  • ๐Ÿช Franchise and cloud-kitchen operators researching market density.
  • ๐Ÿง‘โ€๐Ÿ’ป Developers who need a structured Zomato extractor instead of brittle page parsing.

Why use this scraper?

Zomato pages are useful, but manually copying restaurant cards is slow and inconsistent.

This actor gives you a repeatable Apify workflow with typed fields, a dataset export, API access, scheduled runs, webhooks, and MCP compatibility.

It focuses on public restaurant search data rather than private user accounts, checkout flows, or protected APIs.

Key features

  • โœ… Public Zomato city and cuisine URL input.
  • โœ… Restaurant profile URL and Zomato restaurant ID.
  • โœ… Rating, rating text, review count, and review label.
  • โœ… Cuisines, locality, address, and city.
  • โœ… Cost-for-two and distance when present.
  • โœ… Promoted/new flags for filtering.
  • โœ… Image and featured image URLs.
  • โœ… Optional public cuisine/locality page discovery.
  • โœ… Pay-per-event pricing with one charge per saved restaurant.

Data fields

FieldDescription
restaurantIdZomato restaurant identifier.
nameRestaurant name.
urlPublic Zomato restaurant profile URL.
cityCity slug inferred from the source URL.
localityLocality or area shown by Zomato.
addressPublic address text when available.
cuisinesArray of cuisine names.
cuisineTextCuisines joined as text for spreadsheets.
ratingNumeric rating when available.
ratingTextRating text exactly as shown by Zomato.
reviewCountParsed review count.
costForTwoCost-for-two text, for example โ‚น1,500 for two.
distanceDistance label when present.
isPromotedWhether the card is promoted/sponsored.
isNewWhether Zomato marks the restaurant as new.
imageUrlMain image URL.
featuredImageUrlFeatured image URL when available.
offerTextPublic offer text when present.
sourceUrlZomato page where the record was found.
sourceQueryCuisine/query inferred from the source URL.
scrapedAtISO timestamp of extraction.

How much does it cost to scrape Zomato restaurants?

The actor uses pay-per-event pricing.

There is a small run-start event and a per-restaurant item event.

The exact live tiered prices are shown on the Apify Store pricing tab. The default implementation charges only when a restaurant record is saved, so empty or blocked pages do not create item charges.

Input

{
"startUrls":[
{"url":"https://www.zomato.com/bangalore/restaurants"}
],
"maxItems":50,
"maxPages":20,
"crawlCuisinePages":true,
"includePromoted":true,
"proxyConfiguration":{"useApifyProxy":true,"apifyProxyGroups":["SHADER"]}
}

Input options explained

startUrls

Add one or more public Zomato URLs.

Good examples:

  • https://www.zomato.com/bangalore/restaurants
  • https://www.zomato.com/bangalore/restaurants/biryani
  • https://www.zomato.com/mumbai/restaurants/pizza

maxItems

Maximum number of unique restaurants to save.

Use a small value for smoke tests and a larger value for city/cuisine lead generation.

maxPages

Maximum number of Zomato pages to fetch.

This protects your run from unexpectedly discovering too many cuisine or locality links.

crawlCuisinePages

When true, the actor follows public cuisine/locality links found in the embedded Zomato page state.

This is useful for collecting 100+ restaurants from a city page.

includePromoted

When false, promoted restaurant cards are filtered out.

Keep it true if you want the same visible restaurant universe a Zomato user sees.

Output example

{
"restaurantId":"22243456",
"name":"Ishaara",
"url":"https://www.zomato.com/bangalore/ishaara-church-street-bangalore/info",
"city":"bangalore",
"locality":"Church Street, Bangalore",
"address":"1st Floor, Church Street, Bangalore",
"cuisines":["Modern Indian","Beverages"],
"cuisineText":"Modern Indian, Beverages",
"rating":4.3,
"reviewCount":1276,
"costForTwo":"โ‚น1,500 for two",
"isPromoted":false,
"sourceUrl":"https://www.zomato.com/bangalore/restaurants",
"scrapedAt":"2026-06-26T04:58:56.648Z"
}

How to scrape Zomato restaurant leads

  1. Open the actor on Apify.
  2. Paste one or more public Zomato restaurant, city, or cuisine URLs.
  3. Set maxItems to your target number of restaurants.
  4. Keep crawlCuisinePages enabled for broader city coverage.
  5. Run the actor.
  6. Export the dataset to CSV, JSON, Excel, Google Sheets, or via API.

Tips for better results

  • Start with a city restaurant page for broad discovery.
  • Start with a cuisine URL for targeted prospecting.
  • Increase maxPages when you need more city coverage.
  • Disable promoted cards if you want organic-only restaurant lists.
  • Schedule recurring runs to monitor rating and review-count changes.

Integrations

You can connect the output to:

  • Google Sheets for sales prospecting.
  • CRMs for restaurant outreach workflows.
  • BI dashboards for cuisine and locality analysis.
  • Data warehouses for historical monitoring.
  • Apify webhooks for automatic downstream processing.

API usage with Node.js

import{ ApifyClient }from'apify-client';
const client =newApifyClient({token: process.env.APIFY_TOKEN});
const run =await client.actor('automation-lab/zomato-restaurant-search-scraper').call({
startUrls:[{url:'https://www.zomato.com/bangalore/restaurants'}],
maxItems:100,
maxPages:20,
crawlCuisinePages:true
});
const{ items }=await client.dataset(run.defaultDatasetId).listItems();
console.log(items);

API usage with Python

from apify_client import ApifyClient
import os
client = ApifyClient(os.environ['APIFY_TOKEN'])
run = client.actor('automation-lab/zomato-restaurant-search-scraper').call(run_input={
'startUrls':[{'url':'https://www.zomato.com/bangalore/restaurants'}],
'maxItems':100,
'maxPages':20,
'crawlCuisinePages':True,
})
items = client.dataset(run['defaultDatasetId']).list_items().items
print(items[:3])

API usage with cURL

curl-X POST "https://api.apify.com/v2/acts/automation-lab~zomato-restaurant-search-scraper/runs?token=$APIFY_TOKEN"\
-H'Content-Type: application/json'\
-d'{"startUrls":[{"url":"https://www.zomato.com/bangalore/restaurants"}],"maxItems":100,"maxPages":20,"crawlCuisinePages":true}'

MCP usage

Use this actor from Claude Desktop, Claude Code, or other MCP clients through Apify MCP.

MCP URL:

https://mcp.apify.com/?tools=automation-lab/zomato-restaurant-search-scraper

Claude Code setup:

$claude mcp add apify-zomato-restaurant-search "https://mcp.apify.com/?tools=automation-lab/zomato-restaurant-search-scraper"

Claude Desktop JSON setup:

{
"mcpServers":{
"apify-zomato-restaurant-search":{
"url":"https://mcp.apify.com/?tools=automation-lab/zomato-restaurant-search-scraper"
}
}
}

Example prompts:

  • "Scrape 100 Zomato restaurants from Bengaluru and summarize cuisines by locality."
  • "Find Zomato biryani restaurants in Bengaluru with ratings and profile URLs."
  • "Export Zomato restaurant leads into a spreadsheet-friendly table."

Common workflows

Restaurant lead generation

Run a city page with cuisine discovery enabled, export CSV, then filter by locality, cuisine, rating, and review count.

Cuisine market mapping

Run multiple cuisine URLs such as biryani, pizza, Chinese, and desserts, then compare restaurant counts and ratings.

Local SEO monitoring

Schedule weekly runs for a fixed set of city/cuisine pages and track rating or review-count changes over time.

Limitations

  • The actor extracts public listing data visible in Zomato page state.
  • It does not log in, bypass paywalls, place orders, or collect private account data.
  • Zomato can change page structure; if embedded state changes, extraction may need maintenance.
  • Detail-page-only data and full review text are outside the MVP output.

FAQ and troubleshooting

Why did I get fewer restaurants than maxItems?

The source pages may contain fewer unique restaurant cards, or several cuisine pages may repeat the same restaurants. Increase maxPages, add more start URLs, or enable cuisine discovery.

Why did a URL fail?

Check that the page is a public Zomato restaurant/search/cuisine page and returns normal HTML in a browser. Some old city slugs or malformed cuisine URLs can return 404.

Should I enable proxies?

The actor defaults to the cost-effective Apify SHADER proxy group because Zomato may block direct cloud datacenter traffic. Keep that default unless you have a trusted custom proxy.

Legality and responsible use

This actor extracts publicly available Zomato page data. You are responsible for using the data legally, respecting applicable terms, privacy rules, and local regulations, and avoiding spam or abusive outreach.

Related scrapers

Changelog

0.1

Initial private build for public Zomato restaurant search and cuisine page extraction.

Support

If a public Zomato restaurant page stops working, open an Apify issue with the run ID, input, and expected city/cuisine. Include whether proxies were enabled.

You might also like

Zomato Restaurants Search Scraper

stealth_mode/zomato-restaurants-search-scraper

Scrape comprehensive restaurant data from Zomato search results including menus, ratings, promotions, and delivery options. Ideal for food delivery analytics, competitive research, and market intelligence in India's dynamic F&B sector.

67

Zomato Restaurant Reviews Scraper ๐Ÿฝ๏ธ

easyapi/zomato-restaurant-reviews-scraper

Scrape restaurant reviews from Zomato.com. Extract detailed review data including ratings, review text, user information, and more. Perfect for restaurant analytics, customer feedback analysis, and market research.

Uber Eats Store Search Scraper ๐Ÿฝ๏ธ

easyapi/uber-eats-store-search-scraper

Extract detailed restaurant data from Uber Eats search results. Get comprehensive information about stores including ratings, status, location, and images. Perfect for market research, competitor analysis, and food delivery insights. ๐Ÿฝ๏ธ๐Ÿ”

AllRecipes Search Scraper ๐Ÿณ

easyapi/allrecipes-search-scraper

Scrape recipe search results from AllRecipes.com. Get detailed recipe information including titles, ratings, image URLs, and categories. Perfect for recipe data collection and culinary research.

Zomato Phone Number Scraper โ€“ Cheapest ๐Ÿ“ž๐Ÿฝ๏ธ

contactminerlabs/zomato-phone-number-scraper---cheapest

๐Ÿ” Scrape Zomato Phone Numbers Instantly Enter a keyword and extract phone numbers from Zomato restaurant and partner listings, including business name & profile URL ๐Ÿ“Š Perfect for restaurant partnerships, food delivery services, B2B outreach, sales teams and enriching your CRM & data pipelines ๐Ÿš€

๐Ÿ‘ User avatar

ContactMinerLabs

2

Just Eat Restaurant Scraper ๐Ÿฝ๏ธ

easyapi/just-eat-restaurant-scraper

๐Ÿฝ๏ธ Powerful Just Eat restaurant scraper that extracts comprehensive data including restaurant details, ratings, delivery info, and deals. Perfect for market research, food delivery analysis, and competitor monitoring. Supports custom search URLs and proxy configuration.

Hostelworld Reviews Scraper ๐Ÿจ

easyapi/hostelworld-reviews-scraper

Extract detailed hostel reviews and ratings from Hostelworld.com. Get comprehensive insights into traveler experiences, including ratings for safety, location, staff, and more. Perfect for market research and competitor analysis in the hostel industry. ๐Ÿจโœจ

Grubhub Restaurant Scraper ๐Ÿฝ๏ธ

easyapi/grubhub-restaurant-scraper

Scrape restaurant data from Grubhub including menus, prices, ratings, and delivery information. Extract detailed business information and menu items for market research, price monitoring, or competitor analysis.

51

1.0

(1)

๐Ÿฝ๏ธ Grubhub Restaurant Reviews Scraper

easyapi/grubhub-restaurant-reviews-scraper

Efficiently extract comprehensive customer reviews, ratings, and order details from Grubhub restaurant pages. Get valuable insights into customer satisfaction, menu item popularity, and sentiment analysis with this powerful and reliable scraper.

23

5.0

(1)

TripAdvisor Reviews Scraper

easyapi/tripadvisor-reviews-scraper

Effortlessly extract detailed TripAdvisor hotel reviews with comprehensive data including ratings, user information, and detailed feedback. Perfect for market research, competitor analysis, and hospitality insights. ๐Ÿจโœจ

19

5.0

(1)

Zomato Reviews Scraper ๐Ÿ”๐Ÿ‡ฎ๐Ÿ‡ณ๐Ÿ’ฌ - Cheap

scrapestorm/zomato-reviews-scraper---cheap

๐Ÿ” Easily Scrape Zomato Reviews Enter a restaurant URL to collect real customer reviews from Zomato ๐Ÿฝ๏ธ Get insights such as review text, rating, author, timestamp, experience type & more ๐Ÿ•ต๏ธโ€โ™€๏ธ Seamlessly integrate with tools like Google Drive to automate workflows and boost productivity โšก๐Ÿ“Š

15

4.5

(2)