Skip to main content gottem  — one API for every scraper.
Gaming & Esports
Verified

Steam Scraper

Extract game listings, pricing, reviews, tags, and player counts from the Steam store and community pages. Built on spider-browser .

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

Extract data in minutes.

steam-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://store.steampowered.com/app/1245620/ELDEN_RING/");
await page.content();

const data = await page.evaluate(`(() => {
  const title = document.querySelector("#appHubAppName")?.textContent?.trim();
  const price = document.querySelector(".game_purchase_price, .discount_final_price")?.textContent?.trim();
  const discount = document.querySelector(".discount_pct")?.textContent?.trim();
  const reviewSummary = document.querySelector(".game_review_summary")?.textContent?.trim();
  const releaseDate = document.querySelector(".date")?.textContent?.trim();
  const developer = document.querySelector("#developers_list a")?.textContent?.trim();
  const tags = [];
  document.querySelectorAll(".glance_tags a.app_tag").forEach(el => {
    tags.push(el.textContent?.trim());
  });
  return JSON.stringify({ title, price, discount, reviewSummary, releaseDate, developer, tags: tags.slice(0, 8) });
})()`);

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

One endpoint for store.steampowered.com.

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

POST /fetch/store.steampowered.com/app/1245620/ELDEN_RING/
Game titlePriceDiscountReview scoreRelease dateTags
cURL
curl -X POST https://api.spider.cloud/fetch/store.steampowered.com/app/1245620/ELDEN_RING/ \
  -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/store.steampowered.com/app/1245620/ELDEN_RING/",
    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/store.steampowered.com/app/1245620/ELDEN_RING/", {
  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.

Game titlePriceDiscountReview scoreRelease dateTagsDeveloperPlayer count
Data

Game metadata

Extract prices, reviews, system requirements, and ratings from store.steampowered.com.

Rendering

Store page handling

Handle dynamic storefronts, interactive catalogs, and lazy-loaded content.

Scale

Catalog coverage

Process entire game libraries and mod repositories at scale.

Related

More Gaming & Esports scrapers.

Start

Start scraping store.steampowered.com.

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