Skip to main content gottem  — one API for every scraper.
Finance
Verified

OpenInsider Scraper

Track SEC insider buying and selling transactions, cluster buys, and executive stock activity from OpenInsider. Built on spider-browser .

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

Extract data in minutes.

openinsider-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://openinsider.com/latest-insider-trading");
await page.content();

const data = await page.evaluate(`(() => {
  const trades = [];
  document.querySelectorAll("table.tinytable tbody tr").forEach(el => {
    const filingDate = el.querySelector("td:nth-child(2) a")?.textContent?.trim();
    const ticker = el.querySelector("td:nth-child(4) a")?.textContent?.trim();
    const insiderName = el.querySelector("td:nth-child(5) a")?.textContent?.trim();
    const title = el.querySelector("td:nth-child(6)")?.textContent?.trim();
    const tradeType = el.querySelector("td:nth-child(7)")?.textContent?.trim();
    const price = el.querySelector("td:nth-child(8)")?.textContent?.trim();
    const value = el.querySelector("td:nth-child(11)")?.textContent?.trim();
    if (ticker) trades.push({ filingDate, ticker, insiderName, title, tradeType, price, value });
  });
  return JSON.stringify({ total: trades.length, trades: trades.slice(0, 20) });
})()`);

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

One endpoint for openinsider.com.

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

POST /fetch/openinsider.com/
Filing dateTickerInsider nameTitleTrade typePrice
cURL
curl -X POST https://api.spider.cloud/fetch/openinsider.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/openinsider.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/openinsider.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.

Filing dateTickerInsider nameTitleTrade typePriceSharesValue
Data

Market data capture

Extract real-time quotes, charts, and financial metrics from openinsider.com.

Rendering

Dynamic charts

Full browser rendering for interactive charts, tables, and streaming tickers.

Scale

Bulk screening

Process thousands of tickers and financial instruments concurrently.

Related

More Finance scrapers.

Start

Start scraping openinsider.com.

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