The ZenRows® Universal Scraper API is a versatile tool designed to simplify and enhance the process of extracting data from websites. Whether you’re dealing with static or dynamic content, our API provides a range of features to meet your scraping needs efficiently.

With Premium Proxies, ZenRows gives you access to over 55 million residential IPs from 190+ countries, ensuring 99.9% uptime and highly reliable scraping sessions. Our system also handles advanced fingerprinting, header rotation, and IP management, enabling you to scrape even the most protected sites without needing to manually configure these elements.

ZenRows makes it easy to bypass complex anti-bot measures, handle JavaScript-heavy sites, and interact with web elements dynamically — all with the right features enabled.

Key Features

  • JavaScript Render: Render JavaScript on web pages using a headless browser to scrape dynamic content that traditional methods might miss.

    • Wait times and selectors: Specify wait times and CSS selectors to ensure elements are fully loaded before scraping.
    • Resource blocking: Block unnecessary resources from loading to speed up scraping.
    • JSON response formatting: Receive responses in JSON format, including XHR or Fetch requests.
    • CSS-based data extraction: Extract data using CSS selectors with our CSS extractor feature.
    • Auto-parsing: Automatically parse and extract relevant data from the scraped HTML.
    • Screenshot capabilities: Capture screenshots of the target page, including full-page and specific element screenshots.
    • Various outputs: Lets you specify which data types to extract from the scraped HTML.
    • JavaScript Instructions: Allowing you to interact with web pages dynamically.
  • Premium Proxies: Leverage a vast network of over 55 million residential IPs across 190+ countries, ensuring a 99.9% uptime for uninterrupted scraping.

    • Geolocation selection: Choose the geographical location of the IP address used for the request (for Premium Proxies).
  • Custom Headers: Add custom HTTP headers to your requests for more control.

  • Session management: Use a session ID to maintain the same IP address across multiple requests for up to 10 minutes.

  • Cloudflare bypass: The API is designed to overcome Cloudflare protection, making it easier to scrape protected websites.

  • Language agnostic: While Python examples are provided, the API works with any programming language that can make HTTP requests.

The Universal Scraper API is particularly useful for extracting data from dynamic websites and handling complex scenarios like JavaScript content and web element interactions, without the need to manage proxies or handle dynamic user interactions manually.

Parameter Overview

Customize your scraping requests using the following parameters:

PARAMETERTYPEDEFAULTDESCRIPTION
apikey requiredstringGet Your Free API KeyYour unique API key for authentication
url requiredstringThe URL of the page you want to scrape
js_renderbooleanfalseEnable JavaScript rendering with a headless browser
js_instructionsstringAllows you to interact with the web page dynamically
custom_headersbooleanfalseInclude custom headers in your request
premium_proxybooleanfalseUse premium proxies to make the request harder to detect
proxy_countrystringGeolocation of the IP used to make the request. Only for Premium Proxies
session_idintegerAssign a session ID to maintain the same IP for multiple requests for up to 10 minutes
original_statusbooleanfalseReturn the original HTTP status code from the target page
allowed_status_codesstringReturns the content of the target page even if it fails with a status code on the provided list
wait_forstringWait for a given CSS Selector to load in the DOM before returning the content
waitinteger0Wait a fixed amount of time before returning the content
block_resourcesstringBlock specific resources from loading
json_responsestringfalseObtain the response in JSON format, including data from XHR or Fetch requests
css_extractorstring (JSON)Define CSS Selectors to extract data from the HTML.
autoparsebooleanfalseUse our auto parser algorithm to automatically extract data.
response_typestringGet the content parsed as Markdown, Plaintext or PDF instead of HTML
screenshotbooleanfalseReturns an above-the-fold screenshot of the target page.
screenshot_fullpagebooleanfalseReturns a full-page screenshot of the target page.
screenshot_selectorstringReturns a screenshot of a specific CSS Selector of the target page.
screenshot_formatstringChoose between png and jpeg formats, with PNG being the default
screenshot_qualityintegerApplicable when using JPEG, this parameter allows you to set the quality from 1 to 100
outputsstringLets you specify which data types to extract from the scraped HTML

Pricing

ZenRows® provides flexible plans tailored to different web scraping needs, starting from $69 per month. This entry-level plan allows you to scrape up to 250,000 URLs using basic requests. For more demanding needs, our Enterprise plans scale up to 38 million URLs or more.

For complex or highly protected websites, enabling advanced features like JavaScript rendering (js_render) and Premium Proxies unlocks ZenRows’ full potential, ensuring the best success rate possible.

However, they come at a higher request cost — requests using both js_render and premium_proxy are billed at 25 times the basic request rate.

For detailed information about different plan options and pricing, visit our pricing page and our pricing documentation page.