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

Chartable Scraper

Extract podcast chart rankings, audience reach data, and cross-platform analytics from Chartable tracking platform. Built on spider-browser .

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

Extract data in minutes.

chartable-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://chartable.com/charts/itunes/us-all-podcasts-podcasts");
await page.content(10000);

const data = await page.evaluate(`(() => {
  const shows = [];
  document.querySelectorAll(".chart-row").forEach(el => {
    const rank = el.querySelector(".chart-row__rank")?.textContent?.trim();
    const title = el.querySelector(".chart-row__title")?.textContent?.trim();
    const publisher = el.querySelector(".chart-row__publisher")?.textContent?.trim();
    if (title) shows.push({ rank, title, publisher });
  });
  return JSON.stringify({ total: shows.length, shows: shows.slice(0, 15) });
})()`);

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

One endpoint for chartable.com.

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

POST /fetch/chartable.com/
Show titlePublisherChart rankCategoryReach scorePlatforms
cURL
curl -X POST https://api.spider.cloud/fetch/chartable.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/chartable.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/chartable.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.

Show titlePublisherChart rankCategoryReach scorePlatforms
Metadata

Track & album data

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

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