> ## Documentation Index
> Fetch the complete documentation index at: https://docs.hasdata.com/llms.txt
> Use this file to discover all available pages before exploring further.

# Google Maps Reviews Scraper

Analyze customer sentiment, benchmark against competitors, and surface response-rate gaps for your business. Returns review date, rating, snippet, owner response, likes, review URL, reviewer name/photo/reviews count/local-guide status, place URL, and attached images.

This scraper job is asynchronous. You'll receive a `jobId`, and can fetch results via polling or webhook delivery.

## Request Cost

Each row of data returned consumes **1 credit** from your balance.

<Tip>Credits are deducted only for successful rows.</Tip>

## Example Request

<CodeGroup>
  ```bash cURL theme={null}
  curl --request POST \
    --url 'https://api.hasdata.com/scrapers/google-maps-reviews/jobs' \
    --header 'Content-Type: application/json' \
    --header 'x-api-key: <your-api-key>' \
    --data '{"limit":100,"urls":["https://www.google.com/maps/place/?q=place_id:ChIJFU2bda4SM4cRKSCRyb6pOB8"],"sortBy":"qualityScore"}'
  ```

  ```javascript Node.js theme={null}
  const axios = require('axios').default;

  const options = {
    method: 'POST',
    url: 'https://api.hasdata.com/scrapers/google-maps-reviews/jobs',
    headers: {'Content-Type': 'application/json', 'x-api-key': '<your-api-key>'},
    data: {
      limit: 100,
      urls: ['https://www.google.com/maps/place/?q=place_id:ChIJFU2bda4SM4cRKSCRyb6pOB8'],
      sortBy: 'qualityScore'
    }
  };

  try {
    const { data } = await axios.request(options);
    console.log(data);
  } catch (error) {
    console.error(error);
  }
  ```

  ```python Python theme={null}
  import requests

  url = "https://api.hasdata.com/scrapers/google-maps-reviews/jobs"

  payload = {
      "limit": 100,
      "urls": ["https://www.google.com/maps/place/?q=place_id:ChIJFU2bda4SM4cRKSCRyb6pOB8"],
      "sortBy": "qualityScore"
  }
  headers = {
      "Content-Type": "application/json",
      "x-api-key": "<your-api-key>"
  }

  response = requests.post(url, json=payload, headers=headers)

  print(response.json())
  ```

  ```php PHP theme={null}
  <?php

  $payload = [
      "limit" => 100,
      "urls" => ["https://www.google.com/maps/place/?q=place_id:ChIJFU2bda4SM4cRKSCRyb6pOB8"],
      "sortBy" => "qualityScore",
  ];

  $curl = curl_init();

  curl_setopt_array($curl, [
    CURLOPT_URL => "https://api.hasdata.com/scrapers/google-maps-reviews/jobs",
    CURLOPT_RETURNTRANSFER => true,
    CURLOPT_CUSTOMREQUEST => "POST",
    CURLOPT_POSTFIELDS => json_encode($payload),
    CURLOPT_HTTPHEADER => [
      "Content-Type: application/json",
      "x-api-key: <your-api-key>",
    ],
  ]);

  $response = curl_exec($curl);
  curl_close($curl);

  echo $response;
  ```

  ```java Java theme={null}
  OkHttpClient client = new OkHttpClient();

  MediaType mediaType = MediaType.parse("application/json");
  String json = """
    {
      "limit": 100,
      "urls": [
        "https://www.google.com/maps/place/?q=place_id:ChIJFU2bda4SM4cRKSCRyb6pOB8"
      ],
      "sortBy": "qualityScore"
    }
  """;
  RequestBody requestBody = RequestBody.create(json, mediaType);

  Request request = new Request.Builder()
    .url("https://api.hasdata.com/scrapers/google-maps-reviews/jobs")
    .post(requestBody)
    .addHeader("Content-Type", "application/json")
    .addHeader("x-api-key", "<your-api-key>")
    .build();

  Response response = client.newCall(request).execute();
  ```

  ```csharp C# theme={null}
  using System.Net.Http;
  using System.Text;

  var client = new HttpClient();

  var json = """
  {
    "limit": 100,
    "urls": [
      "https://www.google.com/maps/place/?q=place_id:ChIJFU2bda4SM4cRKSCRyb6pOB8"
    ],
    "sortBy": "qualityScore"
  }
  """;
  var content = new StringContent(json, Encoding.UTF8, "application/json");

  var request = new HttpRequestMessage(new HttpMethod("POST"), "https://api.hasdata.com/scrapers/google-maps-reviews/jobs")
  {
      Content = content,
  };
  request.Headers.Add("x-api-key", "<your-api-key>");

  using var response = await client.SendAsync(request);
  response.EnsureSuccessStatusCode();
  var body = await response.Content.ReadAsStringAsync();
  Console.WriteLine(body);
  ```

  ```ruby Ruby theme={null}
  require 'net/http'
  require 'uri'
  require 'json'

  uri = URI("https://api.hasdata.com/scrapers/google-maps-reviews/jobs")
  payload = {
    "limit" => 100,
    "urls" => ["https://www.google.com/maps/place/?q=place_id:ChIJFU2bda4SM4cRKSCRyb6pOB8"],
    "sortBy" => "qualityScore",
  }

  http = Net::HTTP.new(uri.host, uri.port)
  http.use_ssl = true

  request = Net::HTTP::Post.new(uri)
  request["Content-Type"] = 'application/json'
  request["x-api-key"] = '<your-api-key>'
  request.body = payload.to_json

  response = http.request(request)
  puts response.read_body
  ```

  ```rust Rust theme={null}
  use reqwest::blocking::Client;
  use serde_json::json;

  fn main() -> Result<(), Box<dyn std::error::Error>> {
      let client = Client::new();
      let payload = json!({
          "limit": 100,
          "urls": [
              "https://www.google.com/maps/place/?q=place_id:ChIJFU2bda4SM4cRKSCRyb6pOB8"
          ],
          "sortBy": "qualityScore"
      });
      let res = client
          .post("https://api.hasdata.com/scrapers/google-maps-reviews/jobs")
          .header("Content-Type", "application/json")
          .header("x-api-key", "<your-api-key>")
          .json(&payload)
          .send()?
          .text()?;
      println!("{}", res);
      Ok(())
  }
  ```

  ```go Go theme={null}
  package main

  import (
  	"bytes"
  	"fmt"
  	"io"
  	"net/http"
  )

  func main() {
  	payload := []byte(`{
    "limit": 100,
    "urls": [
      "https://www.google.com/maps/place/?q=place_id:ChIJFU2bda4SM4cRKSCRyb6pOB8"
    ],
    "sortBy": "qualityScore"
  }`)

  	req, _ := http.NewRequest("POST", "https://api.hasdata.com/scrapers/google-maps-reviews/jobs", bytes.NewBuffer(payload))
  	req.Header.Add("Content-Type", "application/json")
  	req.Header.Add("x-api-key", "<your-api-key>")

  	res, _ := http.DefaultClient.Do(req)
  	defer res.Body.Close()

  	responseBody, _ := io.ReadAll(res.Body)
  	fmt.Println(string(responseBody))
  }
  ```
</CodeGroup>

## Job Parameters

<ParamField body="limit" type="number" required>
  Number of reviews
</ParamField>

<ParamField body="urls" type="string[]" required>
  Enter Google Maps Place URLs. Each URL must be on a different line.
</ParamField>

<ParamField body="sortBy" type="string" required>
  Sort By
</ParamField>

## Supported Enrichments

Request any of the fields below via the `enrichments` array in your job payload.

| ID             | Title               | Description                         | Cost per Request |
| -------------- | ------------------- | ----------------------------------- | ---------------- |
| `email`        | Email Address       | Review author email address         | 5 credits        |
| `website`      | Website URL         | Review author website URL           | 5 credits        |
| `phone`        | Phone Number        | Review author phone number          | 5 credits        |
| `linkedinUrl`  | LinkedIn Profile    | Review author LinkedIn profile URL  | 5 credits        |
| `facebookUrl`  | Facebook Profile    | Review author Facebook profile URL  | 5 credits        |
| `instagramUrl` | Instagram Profile   | Review author Instagram profile URL | 5 credits        |
| `xUrl`         | X (Twitter) Profile | Review author X profile URL         | 5 credits        |

## Getting Results

<Card title="Webhooks" horizontal icon="webhook" href="/scrapers/webhooks">
  Receive real-time updates when your scraper job starts, completes, or collects data.
</Card>

<Card title="Results API" horizontal icon="list" href="/scrapers/getting-results">
  Use the Results API to fetch your data using the `jobId`, with support for polling and pagination.
</Card>

<Card title="Stopping a Job" horizontal icon="circle-stop" href="/scrapers/stopping-job">
  Cancel an active scraper job early if it's no longer needed or you want to save credits.
</Card>
