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

Tidal Scraper

Extract hi-fi music catalog data, artist credits, album tracklists, and audio quality info from Tidal streaming service. Built on spider-browser .

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

Extract data in minutes.

tidal-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://tidal.com/browse/playlist/2650ac82-e1bc-4c0a-a0cc-8b08e7174e40");
await page.content(10000);

const data = await page.evaluate(`(() => {
  const tracks = [];
  document.querySelectorAll("[data-testid='tracklist-row']").forEach(el => {
    const title = el.querySelector("[data-testid='tracklist-row-title']")?.textContent?.trim();
    const artist = el.querySelector("[data-testid='tracklist-row-artist']")?.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 tidal.com.

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

POST /fetch/tidal.com/
Track titleArtistAlbumDurationAudio qualityRelease date
cURL
curl -X POST https://api.spider.cloud/fetch/tidal.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/tidal.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/tidal.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 titleArtistAlbumDurationAudio qualityRelease dateCreditsGenre
Metadata

Track & album data

Extract track info, artist data, and play counts from tidal.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 tidal.com.

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