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

Wirecutter Scraper

Extract expert product recommendations, buying guides, and detailed test results from Wirecutter. Built on spider-browser .

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

Extract data in minutes.

wirecutter-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://www.nytimes.com/wirecutter/reviews/best-wireless-headphones/");
await page.content(10000);

const data = await page.evaluate(`(() => {
  const picks = [];
  document.querySelectorAll("[data-testid='product-card']").forEach(el => {
    const name = el.querySelector("[data-testid='product-name']")?.textContent?.trim();
    const pickType = el.querySelector("[data-testid='pick-type']")?.textContent?.trim();
    const price = el.querySelector("[data-testid='product-price']")?.textContent?.trim();
    const summary = el.querySelector("[data-testid='product-summary']")?.textContent?.trim();
    if (name) picks.push({ name, pickType, price, summary: summary?.slice(0, 200) });
  });
  return JSON.stringify({ total: picks.length, picks: picks.slice(0, 10) });
})()`);

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

One endpoint for nytimes.com/wirecutter.

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

POST /fetch/nytimes.com/
Product namePick typePriceRatingProsCons
cURL
curl -X POST https://api.spider.cloud/fetch/nytimes.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/nytimes.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/nytimes.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.

Product namePick typePriceRatingProsConsCategoryTest summary
Listings

Business intelligence

Extract ratings, reviews, and contact info from nytimes.com/wirecutter listings.

Pagination

Review collection

Navigate through paginated reviews with scroll-based lazy loading.

Geo

Location targeting

Access location-specific results with geo-targeted residential proxies.

Related

More Reviews scrapers.

Start

Start scraping nytimes.com/wirecutter.

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