← 返回 Skills 市场
hundevmode

Google Maps Scraper Apify

作者 hundevmode · GitHub ↗ · v1.0.0 · MIT-0
cross-platform ✓ 安全检测通过
47
总下载
0
收藏
0
当前安装
1
版本数
在 OpenClaw 中安装
/install google-maps-scraper-apify
功能描述
Use this skill when the user needs Google Maps business data through an Apify actor, including local business leads, place URLs, Place IDs, websites, phones,...
使用说明 (SKILL.md)

Google Maps Scraper Apify Skill

Overview

This skill helps an AI agent run the Apify Google Maps Scraper actor for local business collection and enrichment.

Default actor:

  • Actor ID: kLdarP5qiTvc9CwtP
  • Actor name: x_guru/google-maps-scraper
  • Store page: https://apify.com/x_guru/google-maps-scraper

Use this skill when a user asks to:

  • collect Google Maps places by search term and location
  • scrape direct Google Maps search URLs or place URLs
  • enrich existing Google Place IDs
  • build local lead lists with websites, phones, addresses, ratings, and coordinates
  • add public website contact extraction
  • extract Google Maps reviews or images
  • create Apify-ready JSON payloads for n8n, CRM, Sheets, or API workflows

Quick Workflow

  1. Clarify the target: business type, location, desired count, and whether add-ons are needed.
  2. Build the smallest useful payload first.
  3. Set a budget guard with Apify maxTotalChargeUsd when the user cares about spend.
  4. Run the actor through scripts/google_maps_scraper_actor.py or the Apify API.
  5. Return summary metrics and dataset rows.
  6. Explain missing fields as normal best-effort behavior when Google Maps or the business website does not expose data.

Payload Rules

  • Standard discovery uses searchStringsArray, locationQuery, and maxCrawledPlacesPerSearch.
  • Exact Google Maps URLs use startUrls as objects: [{"url": "https://www.google.com/maps/..."}].
  • Exact Google Place IDs use placeIds.
  • Structured search area uses countryCode, city, state, county, postalCode, customGeolocation, and strictLocationBounds; locationQuery has priority when present.
  • Broad visible-map collection uses allPlacesNoSearchAction="all_visible" and optional allPlacesZoom; use it only for concrete local areas.
  • Paid filters include placeCategories, customPlaceCategories, searchMatching, minStars, website, and skipClosedPlaces.
  • Use scrapeCompanyContacts only when the user needs public website emails, phones, or social links.
  • Use maxReviews only when the user explicitly needs review rows or review fields.
  • Use maxImages only when the user needs image URLs beyond the main image.
  • Use scrapePlaceDetailPage for richer opening hours, menu links, plus code, inside places, web results, and detailed place metadata.
  • Place details can be extended with scrapeTableReservationProviderData, scrapeOrderOnlineWidgetData, includeWebResults, and scrapeInsidePlaces.
  • Image extraction can be extended with scrapeImageAuthors.
  • Keep initial tests small: 10-50 places before scaling.

Authentication

Use the Apify API token from the environment:

export APIFY_TOKEN='apify_api_xxx'

Never hardcode or print the full token in user-facing output.

Script Usage

Install requirements if your runtime expects a requirements step:

pip install -r requirements.txt

Run a quick search:

APIFY_TOKEN='apify_api_xxx' \
python3 scripts/google_maps_scraper_actor.py quick-search \
  --query "bike repair shop" \
  --location "Portland, Oregon, USA" \
  --limit 25 \
  --budget-usd 1

Run with reviews:

APIFY_TOKEN='apify_api_xxx' \
python3 scripts/google_maps_scraper_actor.py quick-search \
  --query "dentist" \
  --location "Austin, Texas, USA" \
  --limit 20 \
  --reviews 10 \
  --reviews-sort newest \
  --budget-usd 1

Run with website contacts:

APIFY_TOKEN='apify_api_xxx' \
python3 scripts/google_maps_scraper_actor.py quick-search \
  --query "roofing contractor" \
  --location "Denver, Colorado, USA" \
  --limit 50 \
  --with-contacts \
  --only-with-website \
  --budget-usd 2

Run a custom payload:

APIFY_TOKEN='apify_api_xxx' \
python3 scripts/google_maps_scraper_actor.py run \
  --input-file references/sample_input.json \
  --budget-usd 2

Recommended Inputs

Local business discovery

{
  "searchStringsArray": ["bike repair shop"],
  "locationQuery": "Portland, Oregon, USA",
  "maxCrawledPlacesPerSearch": 100,
  "language": "en"
}

Exact URLs

{
  "startUrls": [
    {
      "url": "https://www.google.com/maps/search/restaurants+near+New+York,+NY"
    }
  ],
  "maxCrawledPlacesPerSearch": 100,
  "language": "en"
}

Place IDs

{
  "placeIds": ["ChIJN1t_tDeuEmsRUsoyG83frY4"],
  "maxCrawledPlacesPerSearch": 1,
  "scrapePlaceDetailPage": true
}

Add-on Fields

  • scrapePlaceDetailPage: extra place details.
  • scrapeCompanyContacts: website contact enrichment.
  • maxReviews: reviews per place.
  • reviewsStartDate: optional YYYY-MM-DD review date filter.
  • reviewsSort: newest, mostRelevant, highestRanking, or lowestRanking.
  • reviewsFilterString: keyword filter for review text.
  • reviewsOrigin: all or google.
  • scrapeReviewsPersonalData: include reviewer profile data when allowed.
  • maxImages: additional image URLs per place.

Output Contract

The runner returns JSON with:

  • ok
  • actorId
  • fetchedAt
  • inputUsed
  • itemCount
  • rows[]

Rows are actor dataset items. Common fields include: Core identity:

  • title
  • subTitle
  • description
  • price
  • categoryName
  • categories
  • rank
  • isAdvertisement

Address and geography:

  • address
  • neighborhood
  • street
  • city
  • state
  • postalCode
  • countryCode
  • location
  • locatedIn
  • floor
  • plusCode

Contacts and web presence:

  • website
  • phone
  • phoneUnformatted
  • emails
  • additionalPhones
  • facebooks
  • instagrams
  • linkedIns
  • twitters
  • youtubes
  • tiktoks

Ratings, reviews, and media:

  • totalScore
  • reviewsCount
  • reviewsDistribution
  • reviews
  • reviewsScraped
  • reviewsFetchStatus
  • reviewsFetchMethod
  • reviewsDateFilterStatus
  • imageUrl
  • images
  • imagesCount
  • imageFetchStatus
  • imageFetchMethod
  • imageAuthorsStatus
  • imageCategories

Details and identifiers:

  • openingHours
  • additionalOpeningHours
  • popularTimesLiveText
  • popularTimesLivePercent
  • popularTimesHistogram
  • menu
  • servicesLink
  • reserveTableUrl
  • googleFoodUrl
  • peopleAlsoSearch
  • placesTags
  • reviewsTags
  • gasPrices
  • hotelStars
  • hotelDescription
  • hotelAds
  • placeId
  • fid
  • cid
  • kgmid
  • url
  • searchPageUrl
  • searchPageLoadedUrl
  • searchString
  • language
  • scrapedAt
  • additionalInfo

The hosted actor output page also exposes:

  • dataset link: results
  • run diagnostics link: summary, pointing to RUN_SUMMARY

Agent Response Rules

  • If a run succeeds with zero rows, say that the actor finished but Google Maps returned no matching places for the requested input.
  • If add-on fields are missing, explain that they are best-effort and depend on Google Maps or the business website exposing data.
  • For lead generation requests, recommend scrapeCompanyContacts plus website=withWebsite when the user needs emails.
  • For large jobs, split by city, keyword, or area and use budget limits per run.
  • For compliance-sensitive review workflows, turn scrapeReviewsPersonalData off unless the user explicitly needs reviewer profile fields.

References

  • references/actor-input-guide.md
  • references/sample_input.json
  • references/troubleshooting.md
安全使用建议
Install only if you are comfortable giving the skill an Apify token and sending requested Google Maps scraping jobs to Apify. Use small limits and budget caps, avoid collecting reviewer profile data unless you have a clear lawful need, and handle emails, phone numbers, social links, reviews, and image-author data according to applicable privacy, platform, retention, and anti-spam rules.
能力评估
Purpose & Capability
The stated purpose is Google Maps business data collection through an Apify actor, and the artifacts consistently document business fields, contacts, reviews, images, Place IDs, budget controls, and JSON output.
Instruction Scope
Scraping add-ons are optional and generally user-directed; reviewer personal data is specifically cautioned against unless explicitly needed, though privacy and legal handling guidance is brief.
Install Mechanism
Installation is a normal skills CLI/GitHub skill install with no hidden postinstall behavior, and requirements.txt declares no third-party runtime dependencies.
Credentials
The required APIFY_TOKEN and python3 runtime are proportionate to running the Apify actor; the script uses the token only to call Apify and does not print it in normal output.
Persistence & Privilege
No background workers, persistence, privilege escalation, local credential harvesting, deletion, or unrelated filesystem mutation were found; the script reads optional input JSON and sends the requested payload to Apify.
如何使用
  1. 确保已安装 OpenClaw(本地或 Docker 部署)
  2. 在对话框中输入安装命令:/install google-maps-scraper-apify
  3. 安装完成后,直接呼叫该 Skill 的名称或使用 /google-maps-scraper-apify 触发
  4. 根据 Skill 的参数说明提供必要输入,即可获得结构化输出
版本历史
v1.0.0
Initial release
元数据
Slug google-maps-scraper-apify
版本 1.0.0
许可证 MIT-0
累计安装 0
当前安装数 0
历史版本数 1
常见问题

Google Maps Scraper Apify 是什么?

Use this skill when the user needs Google Maps business data through an Apify actor, including local business leads, place URLs, Place IDs, websites, phones,... 它是一个面向 Claude Code / OpenClaw 的 AI Agent Skill 插件,目前累计下载 47 次。

如何安装 Google Maps Scraper Apify?

在 OpenClaw 或 Claude Code 对话框中运行命令「/install google-maps-scraper-apify」即可一键安装,无需额外配置。

Google Maps Scraper Apify 是免费的吗?

是的,Google Maps Scraper Apify 完全免费,采用 MIT-0 许可证,可自由下载、安装和使用。

Google Maps Scraper Apify 支持哪些平台?

Google Maps Scraper Apify 跨平台运行,可在任意部署了 OpenClaw / Claude Code 的环境中使用(cross-platform)。

谁开发了 Google Maps Scraper Apify?

由 hundevmode(@hundevmode)开发并维护,当前版本 v1.0.0。

💬 留言讨论