Skip to main content gottem  — one API for every scraper.
Home Services
Verified

Handy Scraper

Extract home cleaning and handyman service pricing, time slot availability, and service packages from Handy booking platform. Built on spider-browser .

Get started Docs
target
handy.com
success rate
99.9%
latency
~4ms
Quick start

Extract data in minutes.

handy-scraper.ts
import { SpiderBrowser } from "spider-browser";

const spider = new SpiderBrowser({
  apiKey: process.env.SPIDER_API_KEY!,
  stealth: 2,
});

await spider.connect();
const page = spider.page!;
await page.goto("https://www.handy.com/services/home-cleaning");
await page.content(10000);

const data = await page.evaluate(`(() => {
  const services = [];
  document.querySelectorAll(".service-card, .pricing-option").forEach(el => {
    const service = el.querySelector("h3, .service-title")?.textContent?.trim();
    const price = el.querySelector(".price, .rate")?.textContent?.trim();
    const duration = el.querySelector(".duration, .time-estimate")?.textContent?.trim();
    const description = el.querySelector(".description, .service-desc")?.textContent?.trim();
    if (service) services.push({ service, price, duration, description });
  });
  return JSON.stringify({ total: services.length, services: services.slice(0, 10) });
})()`);

console.log(JSON.parse(data));
await spider.close();
ready to run · spider-browser · TypeScript
Fetch API

One endpoint for handy.com.

Structured JSON from handy.com with a single POST. AI-resolved selectors, cached on the first call.

POST /fetch/handy.com/
Service typeBase priceDurationAvailable dateTime slotAdd-on services
cURL
curl -X POST https://api.spider.cloud/fetch/handy.com/ \
  -H "Authorization: Bearer YOUR_API_KEY" \
  -H "Content-Type: application/json" \
  -d '{"return_format": "json"}'
Python
import requests

resp = requests.post(
    "https://api.spider.cloud/fetch/handy.com/",
    headers={
        "Authorization": "Bearer YOUR_API_KEY",
        "Content-Type": "application/json",
    },
    json={"return_format": "json"},
)
print(resp.json())
Node.js
const resp = await fetch("https://api.spider.cloud/fetch/handy.com/", {
  method: "POST",
  headers: {
    "Authorization": "Bearer YOUR_API_KEY",
    "Content-Type": "application/json",
  },
  body: JSON.stringify({ return_format: "json" }),
});
const data = await resp.json();
console.log(data);
Extraction

Fields you can pull.

Service typeBase priceDurationAvailable dateTime slotAdd-on servicesFrequency discountService area
Listings

Provider search

Extract contractor profiles, ratings, and availability from handy.com.

Geo

Local targeting

Access location-specific service providers with geo-targeted proxies.

Data

Review aggregation

Extract ratings, reviews, and pricing from home service marketplaces.

Related

More Home Services scrapers.

Start

Start scraping handy.com.

Grab an API key and call the endpoint above. The first request resolves the config; every request after hits cache.