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

Setlist.fm Scraper

Extract concert setlists, venue data, tour dates, and fan-submitted song lists from Setlist.fm live music database. Built on spider-browser .

Get started Docs
target
setlist.fm
success rate
99.9%
latency
~4ms
Quick start

Extract data in minutes.

setlistfm-scraper.ts
import { SpiderBrowser } from "spider-browser";

const spider = new SpiderBrowser({
  apiKey: process.env.SPIDER_API_KEY!,
});

await spider.connect();
const page = spider.page!;
await page.goto("https://www.setlist.fm/setlists/radiohead-bd6bd12.html");
await page.content();

const data = await page.evaluate(`(() => {
  const setlists = [];
  document.querySelectorAll(".setlistPreview").forEach(el => {
    const date = el.querySelector(".dateBlock .month, .dateBlock .day")?.textContent?.trim();
    const venue = el.querySelector(".setlistMainLine a:nth-child(2)")?.textContent?.trim();
    const city = el.querySelector(".setlistMainLine span")?.textContent?.trim();
    const songs = [];
    el.querySelectorAll(".songPart a").forEach(s => songs.push(s.textContent?.trim()));
    if (venue) setlists.push({ date, venue, city, songs: songs.slice(0, 5) });
  });
  return JSON.stringify({ total: setlists.length, setlists: setlists.slice(0, 10) });
})()`);

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

One endpoint for setlist.fm.

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

POST /fetch/setlist.fm/
ArtistVenueDateCitySongs playedTour name
cURL
curl -X POST https://api.spider.cloud/fetch/setlist.fm/ \
  -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/setlist.fm/",
    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/setlist.fm/", {
  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.

ArtistVenueDateCitySongs playedTour nameEncoreSetlist votes
Metadata

Track & album data

Extract track info, artist data, and play counts from setlist.fm.

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 setlist.fm.

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