
SuperScraper API
Pricing
Pay per usage

SuperScraper API
Generic REST API for scraping websites: send a URL and get back HTML. This Actor is a drop-in replacement for ScrapingBee, ScrapingAnt, and ScraperAPI services. And it is open-source!
4.1 (6)
Pricing
Pay per usage
43
769
26
Last modified
a month ago
SuperScraper API is an Actor that provides a REST API for scraping websites. Just pass the URL of a web page and get back the fully rendered HTML content. SuperScraper API is compatible with ScrapingBee, ScrapingAnt, and ScraperAPI interfaces.
Main features:
- Extract HTML from arbitrary URLs with a headless browser for dynamic content rendering.
- Circumvent blocking using datacenter or residential proxies, as well as browser fingerprinting.
- Seamlessly scale to a large number of web pages as needed.
- Capture screenshots of the web pages.
Note that SuperScraper API uses the new experimental Actor Standby mode, so it's not started the traditional way from Apify Console. Instead, it's invoked via the HTTP REST API provided directly by the Actor. See the examples below.
Usage examples
To run these examples, you need an Apify API token, which you can find under Settings > Integrations in Apify Console.
You can create an Apify account free of charge.
Node.js
curl
Authentication
The best way to authenticate is to pass your Apify API token using the Authorization HTTP header.
Alternatively, you can pass the API token via the token query parameter to authenticate the requests, which is more convenient for testing in a web browser.
Node.js
curl
Pricing
When using SuperScraper API, you're charged based on your actual usage of the Apify platform's computing, storage, and networking resources.
Cost depends on the target sites, your settings and API parameters, the load of your requests, and random network and target site conditions.
The best way to see your price is to conduct a real-world test.
An example cost on a free account (the pricing is cheaper on higher plans) for 30 one-by-one requests plus 50 batched requests test:
| parameters | cost estimate | 
|---|---|
| no render_js+ basic proxy | $1/1000 requests | 
| no render_js+ premium (residential) proxy | $2/1000 requests | 
| render_js+ basic proxy | $4/1000 requests | 
| render_js+ premium (residential) proxy | $5/1000 requests | 
API parameters
ScrapingBee API parameters
SuperScraper API supports most of the API parameters of ScrapingBee:
| parameter | description | 
|---|---|
| url | URL of the webpage to be scraped. This parameter is required. | 
| json_response | Return a verbose JSON response with additional details about the webpage. Can be either trueorfalse, default isfalse. | 
| extract_rules | A stringified JSON containing custom rules how to extract data from the webpage. | 
| render_js | Indicates that the webpage should be scraped using a headless browser, with dynamic content rendered. Can be trueorfalse, default istrue. This is equivalent to ScrapingAnt'sbrowser. | 
| screenshot | Get screenshot of the browser's current viewport. If json_responseis set totrue, screenshot will be returned in the Base64 encoding. Can betrueorfalse, default isfalse. | 
| screenshot_full_page | Get screenshot of the full page. If json_responseis set totrue, screenshot will be returned in the Base64 encoding. Can betrueorfalse, default isfalse. | 
| screenshot_selector | Get screenshot of the element specified by the selector. If json_responseis set totrue, screenshot will be returned in Base64. Must be a non-empty string. | 
| js_scenario | JavaScript instructions that will be executed after loading the webpage. | 
| wait | Specify a duration that the browser will wait after loading the page, in milliseconds. | 
| wait_for | Specify a CSS selector of an element for which the browser will wait after loading the page. | 
| wait_browser | Specify a browser event to wait for. Can be either load,domcontentloaded, ornetworkidle. | 
| block_resources | Specify that you want to block images and CSS. Can be trueorfalse, default istrue. | 
| window_width | Specify the width of the browser's viewport, in pixels. | 
| window_height | Specify the height of the browser's viewport, in pixels. | 
| cookies | Custom cookies to use to fetch the web pages. This is useful for fetching webpage behing login. The cookies must be specified in a string format: cookie_name_1=cookie_value1;cookie_name_2=cookie_value_2. | 
| own_proxy | A custom proxy to be used for scraping, in the format <protocol><username>:<password>@<host>:<port>. | 
| premium_proxy | Use residential proxies to fetch the web content, in order to reduce the probability of being blocked. Can be either trueorfalse, default isfalse. | 
| stealth_proxy | Works same as premium_proxy. | 
| country_code | Use IP addresses that are geolocated in the specified country by specifying its 2-letter ISO code. When using code other than US,premium_proxymust be set totrue. This is equivalent to setting ScrapingAnt'sproxy_country. | 
| custom_google | Use this option if you want to scrape Google-related websites (such as Google Searach or Google Shopping). Can be trueorfalse, default isfalse. | 
| return_page_source | Return HTML of the webpage from the response before any dynamic JavaSript rendering. Can be trueorfalse, default isfalse. | 
| transparent_status_code | By default, if target webpage responds with HTTP status code other than a 200-299 or a 404, the API will return a HTTP status code 500. Set this paremeter to trueto disable this behavior and return the status code of the actual response. | 
| timeout | Set maximum timeout for the response from this Actor, in milliseconds. The default is 140 000 ms. | 
| forward_headers | If set to true, HTTP headers starting with prefixSpb-orAnt-will be forwarded to the target webpage alongside headers generated by us (the prefix will be trimmed). | 
| forward_headers_pure | If set to true, only headers starting with prefixSpb-orAnt-will be forwarded to the target webpage (prefix will be trimmed), without any other HTTP headers from our side. | 
| device | Can be either desktop(default) ormobile. | 
ScrapingBee's API parameters block_ads and session_id are currently not supported.
ScrapingAnt API parameters
SuperScraper API supports most of the API parameters of ScrapingAnt:
| parameter | description | 
|---|---|
| url | URL of the webpage to be scraped. This parameter is required. | 
| browser | Indicates that the webpage should be scraped using a headless browser, with dynamic content rendered. Can be trueorfalse, default istrue. This is equivalent as ScrapingBee'srender_js. | 
| cookies | Use custom cookies, must be in a string format: cookie_name_1=cookie_value1;cookie_name_2=cookie_value_2. | 
| js_snippet | A Base64-encoded JavaScript code to be executed on the webpage. Will be treated as the evaluate instruction. | 
| proxy_type | Specify the type of proxies, which can be either datacenter(default) orresidential. This is equivalent to setting ScrapingBee'spremium_proxyorsteath_proxytotrue. | 
| wait_for_selector | Specify a CSS selector of an element for which the browser will wait after loading the page. This is equivalent to setting ScrapingBee's wait_for. | 
| block_resource | Specify one or more resources types you want to block from being downloaded. The parameter can be repeated in the URL (e.g. block_resource=image&block_resource=media). Available options are:document,stylesheet,image,media,font,script,texttrack,xhr,fetch,eventsource,websocket,manifest,other. | 
| return_page_source | Return HTML of the webpage from the response before any dynamic JavaSript rendering. Can be trueorfalse, default isfalse. | 
| proxy_country | Use IP addresses that are geolocated in the specified country by specifying its 2-letter ISO code. When using code other than US,premium_proxymust be set totrue. This is equivalent to setting ScrapingBee'scountry_code. | 
ScrapingAnt's API parameter x-api-key is not supported.
Note that HTTP headers in a request to this Actor beginning with prefix Ant- will be forwarded (without the prefix) to the target webpage alongside headers generated by the Actor.
This behavior can be changed using ScrapingBee's forward_headers or forward_headers_pure parameters.
ScraperAPI API parameters
SuperScraper API supports most of the API parameters of ScraperAPI:
| parameter | description | 
|---|---|
| url | URL of the webpage to be scraped. This parameter is required. | 
| render | Specify, if you want to scrape the webpage with or without using a headless browser, can be trueorfalse, defaulttrue. (Same asrender_js.) | 
| wait_for_selector | Specify a CSS selector of an element for which the browser will wait after loading the page. This is equivalent to setting ScrapingBee's wait_for. | 
| premium | Use residential proxies to fetch the web content, in order to reduce the probability of being blocked. Can be either trueorfalse, default isfalse. This is equivalent to setting ScrapingBee'spremium_proxy. | 
| ultra_premium | Same as premium. | 
| country_code | Use IP addresses that are geolocated in the specified country by specifying its 2-letter ISO code. When using code other than US,premium_proxymust be set totrue. This is equivalent to setting ScrapingAnt'sproxy_country. | 
| keep_headers | If true, then all headers sent to this Actor will be forwarded to the target website. TheAuthorizationheader will be removed. | 
| device_type | Can be either desktop(default) ormobile. This is equivalent to setting ScrapingBees'sdevice. | 
| binary_target | Specify whether the target is a file. Can be trueorfalse, default isfalse. Currently only supported when JS rendering is set tofalsevia therender_js,browser, orrenderparameters. | 
ScraperAPI's API parameters session_number and autoparse are currently not supported, and they are ignored.
Custom extraction rules
Using ScrapingBee's extract_rules parameter, you can specify a set of rules to extract specific data from the target web pages. You can create an extraction rule in one of two ways: with shortened options, or with full options.
Shortened options
- value for the given key serves as a selector
- using @, we can access attribute of the selected element
Example:
Full options
- selectoris required
- typecan be either- item(default) or- list
- outputindicates how the result for these element(s) will look like. It can be:- text(default option when- outputis omitted) - text of the element
- html- HTML of the element
- attribute name (starts with @, for example@href)
- object with other extract rules for the given item (key + shortened or full options)
- table_jsonor- table_arrayto scrape a table in a json or array format
 
- clean- relevant when having- textas- output, specifies whether the text of the element should be trimmed of whitespaces (can be- trueor- false, default- true)
Example:
Example
This example extracts all links from Apify Blog along with their titles.
The results look like this:
Custom JavaScript code
Use ScrapingBee's js_scenario parameter to specify instructions in order to be executed one by one after opening the page.
Set json_response to true to get a full report of the executed instructions, the results of evaluate instructions will be added to the evaluate_results field.
Example of clicking a button:
Strict mode
If one instruction fails, then the subsequent instructions will not be executed. To disable this behavior, you can optionally set strict to false (by default it's true):
Supported instructions
wait
- wait for some time specified in ms
- example: {"wait": 10000}
wait_for
- wait for an element specified by the selector
- example {"wait_for": "#element"}
click
- click on an element specified by the selector
- example {"click": "#button"}
wait_for_and_click
- combination of previous two
- example {"wait_for_and_click": "#button"}
scroll_x and scroll_y
- scroll a specified number of pixels horizontally or vertically
- example {"scroll_y": 1000}or{"scroll_x": 1000}
fill
- specify a selector of the input element and the value you want to fill
- example {"fill": ["input_1", "value_1"]}
evaluate
- evaluate custom javascript on the webpage
- text/number/object results will be saved in the evaluate_resultsfield
- example {"evaluate":"document.querySelectorAll('a').length"}

















