Skip to main content gottem  — one API for every scraper.
Music & Podcasts
Verified

Spotify Music Scraper

Extract playlist tracks, artist profiles, album metadata, and popularity scores from Spotify open web player. Built on spider-browser .

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

Extract data in minutes.

spotify-music-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://open.spotify.com/playlist/37i9dQZF1DXcBWIGoYBM5M");
await page.content(12000);

const data = await page.evaluate(`(() => {
  const tracks = [];
  document.querySelectorAll("[data-testid='tracklist-row']").forEach(el => {
    const title = el.querySelector("[data-testid='internal-track-link'] div")?.textContent?.trim();
    const artist = el.querySelector("[data-testid='tracklist-row__artist-name-link']")?.textContent?.trim();
    const duration = el.querySelector("[data-testid='tracklist-row__duration']")?.textContent?.trim();
    if (title) tracks.push({ title, artist, duration });
  });
  return JSON.stringify({ total: tracks.length, tracks: tracks.slice(0, 15) });
})()`);

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

One endpoint for open.spotify.com.

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

POST /fetch/open.spotify.com/
Track nameArtistAlbumDurationPopularityRelease date
cURL
curl -X POST https://api.spider.cloud/fetch/open.spotify.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/open.spotify.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/open.spotify.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.

Track nameArtistAlbumDurationPopularityRelease dateGenrePreview URL
Metadata

Track & album data

Extract track info, artist data, and play counts from open.spotify.com.

Rendering

Player handling

Handle embedded players, dynamic playlists, and streaming interfaces.

Scale

Catalog coverage

Process entire artist catalogs and podcast libraries at scale.

Related

More Music & Podcasts scrapers.

Start

Start scraping open.spotify.com.

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