all scrapers
E-commerce

Scrape any Shopify store’s products into JSON

Point one API call at any Shopify product page and get the title, price, variants, and availability back as schema-validated JSON — it works across stores.

One call

Send the URL and a plain-language description of the fields. That's the whole integration.

curl https://api.webscrape.ai/v1/smartscraper \
  -H "X-API-Key: wsg_live_your_key_here" \
  -H "Content-Type: application/json" \
  -d '{
    "url": "https://store.example.com/products/example-product",
    "prompt": "Extract the product title, price, the available variants, and whether it is in stock."
  }'

You get back JSON shaped to match — nothing to parse:

{
  "status": "completed",
  "data": {
    "title": "string",
    "price": "number",
    "variants": "string[]",
    "in_stock": "boolean"
  }
}

Example response shape; data matches the fields you asked for. Failed fetches return a non-completed status and cost nothing.

Fields you'll usually want from Shopify storefronts

FieldTypeWhat it is
titlestringProduct title
pricenumberCurrent price
variantsstring[]Available variants
in_stockbooleanAvailability

Most Shopify stores also expose a public product JSON endpoint (append .json to a product URL); the page route works when you want the rendered view.

How it works

  • Tiered fetching. A fast request carrying a real browser's fingerprint handles most pages; the engine steps up to a headless browser, then our hardened stealth browser, only when a page forces it.
  • AI extraction. The cleaned page is extracted into data matching your fields, validated against the schema with one repair pass on a miss.
  • One wallet, success-only. Proxies, browser time, and extraction all come out of one credit balance, and a failed fetch costs nothing.
  • Blueprints for repeat runs. Once an extraction works, pin it: subsequent runs replay reverse-engineered selectors with no AI step in the loop.

When it breaks

  • A page returns a 200 with an empty shell: that can look like success to the fast tier, so force the browser tier for that request if it recurs.
  • A field comes back wrong after a redesign: re-run live extraction, or re-pin the Blueprint. Drift surfaces as validation_warnings, not a silent null.

FAQ

Is there a Shopify storefronts scraping API?

Point webscrape.ai's /v1/smartscraper endpoint at a Shopify storefronts URL and describe the fields you want. You get schema-validated JSON back, with no separate proxy or browser to set up.

Do I need proxies to scrape Shopify storefronts?

No. The tiered fetch stack handles the proxy and browser tiers for you, and they come out of one credit balance. You only pay the stealth surcharge if a page actually needs the browser tier.

What happens when Shopify storefronts changes its layout?

Live extraction is anchored to the fields you describe, so it survives most redesigns. For repeat runs you can pin a Blueprint; if the page drifts, the run returns validation_warnings instead of silently dropping fields.

Grab a key and point it at a Shopify storefronts page. New accounts get free credits — no card.