Google Maps Business Scraper — Local Leads & Place Data
Pricing
from $4.00 / 1,000 places
Google Maps Business Scraper — Local Leads & Place Data
Scrape Google Maps business listings — 27 fields per place: name, address, phone, website, rating, reviews, category, lat/lng, hours, amenities, parse_confidence. For lead generation, market research, competitor analysis. Apify residential proxy — no external key needed.
Pricing
from $4.00 / 1,000 places
Rating
0.0
(0)
Developer
Vitalii Bondarev
Maintained by CommunityActor stats
0
Bookmarked
2
Total users
1
Monthly active users
3 days ago
Last modified
Categories
Share
Google Maps Scraper — Local Leads, Contacts & Place Data
Extract Google Maps business listings at scale — name, address, phone, website + emails + social links, rating, review count, category, latitude/longitude, plus-code, price level, structured opening hours, amenity tags, owner-verified flag, and more. This Google Maps scraper returns 32 fields per place, each carrying a parse_confidence score and a parse_path flag, so you always know your data is clean — not silently broken.
Built for lead generation, local SEO audits, market research, and competitor analysis across any city, region, or business category. No Google API key, no external proxy key — it runs entirely on Apify's residential proxy.
Why this Google Maps scraper stands out
- Contact enrichment is INCLUDED, not a paid add-on. Flip on
scrapeContactsand every record gainsemailsandsocial_links(Facebook, Instagram, LinkedIn, X/Twitter, YouTube, TikTok, …) pulled from the business website. The market leader charges roughly +$2 per 1,000 places for emails/social as a separate add-on; here it is part of the same run at the same price. - Breaks the 20-result ceiling. The actor auto-paginates (via the Maps
!8ioffset token) to return up to 300 places per query, deduplicated by place ID across pages — instead of the single 20-place page most lightweight scrapers stop at. - A real B-plan against format drift. Google reshuffles its internal response layout between releases — the classic silent killer that makes index-based scrapers return zero results that look like an empty area. This actor has a secondary regex/structural parser that recovers places by stable feature-ID anchors when the primary array-index path drifts. Recovered rows are flagged (
parse_path: "fallback", lowerparse_confidence) so degradation is visible, never silent. - Self-rotating against blocks. On a CAPTCHA / consent wall / poisoned IP, the actor rotates to a fresh residential exit and retries (up to 3×) before giving up on a query — and it never charges you for a blocked or empty query.
- 32 rich fields — including
is_claimed(owner-verified),plus_code,opening_hours(structured weekday list),summary,description,price_level(numeric 0–4),place_id(ChIJ),amenities, andparse_confidence. - No external key, $0 setup. Uses the Apify residential proxy pool that ships with your account. No Bright Data token, no Google Cloud project.
How it compares
| This actor | compass/crawler-google-places | lukaskrivka/…-contact-details | |
|---|---|---|---|
| Base price (per 1k places) | $1.00 | ~$2.10–$5.00 | ~$2.10 |
| Emails + social links | ✅ included | ➕ paid add-on (+~$2/1k) | ✅ (separate actor) |
| Results per query | up to 300 (auto-paginate) | ~120–300 | ~120 |
| Format-drift fallback parser | ✅ regex B-plan | — | — |
| Per-record quality score | ✅ parse_confidence | — | — |
| External key required | ❌ none | ❌ none | ❌ none |
(Competitor prices/behaviour as observed on the Apify Store, 2026-06; verify current pricing on each listing.)
Input
| Field | Type | Required | Description |
|---|---|---|---|
queries | array of strings | ✅ | Search queries, e.g. ["coffee shops in San Francisco CA", "plumbers near Austin TX"]. Each query is paginated up to maxResults. |
maxResults | integer | — | Max places per query, 1–300 (default 20). The actor paginates automatically. Google caps a single area near 120–300; split into narrower queries for fuller coverage. |
scrapeContacts | boolean | — | Visit each business website to extract emails + social_links. Default false. Slower, but included at no extra charge. |
language | string | — | Result language code (BCP-47). Default en. |
country | string | — | Country code for result localisation. Default us. |
proxyConfiguration | object | — | Apify proxy settings. Must be residential — Google Maps blocks datacenter IPs. Default: Apify RESIDENTIAL group. (Note: the GOOGLE_SERP group does not support Maps.) |
Output schema (32 fields)
| Field | Type | Description |
|---|---|---|
place_id | string | Google place ID in ChIJ format |
place_id_raw | string | Raw hex feature ID (0x…:0x…) |
name | string | Business name |
address | string | Full street address |
latitude / longitude | float | Coordinates |
plus_code | string | Open Location Code (e.g. 849VCWC8+R9) |
phone | string | Phone number |
website | string | Business website URL |
emails | array | Public emails from the website (when scrapeContacts on) |
social_links | object | {platform: url} social profiles (when scrapeContacts on) |
contact_enriched | bool | Whether website enrichment ran for this record |
category | string | Primary category (e.g. "Coffee shop") |
categories | array | All category objects [{id, title}] |
rating | float | Star rating 0.0–5.0 |
reviews_count | int | Number of reviews |
price_range | string | Textual price range (e.g. "$1–10") |
price_level | int | Numeric price level 0–4 (0=free, 4=very expensive) |
work_status | string | Open/closed status (e.g. "Open · Closes 9 PM") |
opening_hours | array | Structured weekly hours [{day, hours}] |
is_claimed | bool | Whether the listing is claimed/owner-verified |
summary | string | Short tagline from Google Business Profile |
description | string | Longer business description |
image_url | string | Main listing image URL |
amenities | array | Positive amenity/attribute strings |
maps_url | string | Direct Google Maps link |
parse_confidence | float | Per-record data-quality score 0.0–1.0 |
parse_path | string | "primary" (array-index) or "fallback" (regex recovery) |
warnings | array | Machine-readable quality-warning codes |
query | string | The search query that produced this result |
rank | int | Position in the result set (1-based) |
scraped_at | string | ISO-8601 UTC timestamp |
Use cases for Google Maps data extraction
- Lead generation — build prospect lists of restaurants, contractors, dentists, gyms, or any local business type by city, complete with phone, website, email, and socials.
- Local SEO audit — bulk-pull competitor ratings, review counts, and owner-verified (
is_claimed) status. - Market research — map category distribution, price tiers, and amenity coverage across a metro area.
- Sales prospecting — export name + phone + website + email straight to your CRM in one pass.
- Real-estate & territory analysis — enrich locations with nearby businesses, services, and coordinates.
Frequently asked questions
Do I need a Google API key or a proxy key? No. The actor runs on the Apify residential proxy pool included with your account. No Google Cloud project, no Bright Data token, nothing external.
How many results per query? Up to 300, paginated automatically. Google itself limits a single area to roughly 120–300 places; for exhaustive coverage of a large city, split the search into narrower queries (per neighborhood or subcategory).
How does the email/social enrichment work? With scrapeContacts on, the actor fetches each business website (homepage and, if needed, /contact) over the same residential proxy and extracts public emails and social-profile links. Hit-rate depends on what the business publishes — some sites list nothing. Records without a website come back with contact_enriched: false.
Is the data stable? It's resilient by design. The primary parser reads Google's structured internal Maps JSON; if Google reshuffles the layout, a secondary regex parser recovers places by stable anchors and flags them (parse_path: "fallback"), and parse_confidence drops so you see the change before it silently corrupts your pipeline.
What does parse_confidence mean? A float 0.0–1.0. Values ≥ 0.9 mean all critical fields were extracted cleanly on the primary path. Lower values (or a regex_fallback_path warning) signal a format change worth checking.
Will I get charged for failed queries? No. The actor charges per place pushed to the dataset, after the push. Blocked, empty, or errored queries push nothing and cost nothing.
Pricing
Pay-per-result: $1.00 per 1,000 places ($0.001 per record) — contact enrichment included, no add-on fees. You pay only for places actually delivered to your dataset.
Not affiliated with Google
This actor is not affiliated with, endorsed by, or sponsored by Google LLC. Google Maps and Google are trademarks of Google LLC. Scrape responsibly and in compliance with applicable laws and terms.