NEW AI Studio is now available Try it now
Music & Podcasts

Tidal Scraper

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

Get Started Documentation
tidal.com target
99.5% success rate
~4ms latency
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

Structured data endpoint

Extract structured JSON from tidal.com with a single POST request. AI-configured selectors, cached for fast repeat calls.

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

Data you can extract

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 scraping tidal.com

Get your API key and start extracting data in minutes.