Website Content Crawler
No credit card required
Website Content Crawler
No credit card required
Crawl websites and extract text content to feed AI models, LLM applications, vector databases, or RAG pipelines. The Actor supports rich formatting using Markdown, cleans the HTML, downloads files, and integrates well with 🦜🔗 LangChain, LlamaIndex, and the wider LLM ecosystem.
Do you want to learn more about this Actor?
Get a demoStart URLs
startUrls
arrayRequired
One or more URLs of pages where the crawler will start.
By default, the Actor will also crawl sub-pages of these URLs. For example, for start URL https://example.com/blog
, it will crawl also https://example.com/blog/post
or https://example.com/blog/article
. The Include URLs (globs) option overrides this automation behavior.
Consider URLs from Sitemaps
useSitemaps
booleanOptional
If enabled, the crawler will look for Sitemaps at the domains of the provided Start URLs and enqueue matching URLs similarly as the links found on crawled pages. You can also reference a sitemap.xml
file directly by adding it as another Start URL (e.g. https://www.example.com/sitemap.xml
)
This feature makes the crawling more robust on websites that support Sitemaps, as it includes pages that might be not reachable from Start URLs. Note that if a page is found via a Sitemap, it will have depth 1.
Default value of this property is false
Crawler type
crawlerType
EnumOptional
Select the crawling engine:
- Headless web browser - Useful for modern websites with anti-scraping protections and JavaScript rendering. It recognizes common blocking patterns like CAPTCHAs and automatically retries blocked requests through new sessions. However, running web browsers is more expensive as it requires more computing resources and is slower. It is recommended to use at least 8 GB of RAM.
- Stealthy web browser (default) - Another headless web browser with anti-blocking measures enabled. Try this if you encounter bot protection while scraping. For best performance, use with Apify Proxy residential IPs.
- Adaptive switching between Chrome and raw HTTP client - The crawler automatically switches between raw HTTP for static pages and Chrome browser (via Playwright) for dynamic pages, to get the maximum performance wherever possible.
- Raw HTTP client - High-performance crawling mode that uses raw HTTP requests to fetch the pages. It is faster and cheaper, but it might not work on all websites.
Beware that with the raw HTTP client or adaptive crawling mode, some features are not available, e.g. wait for dynamic content, maximum scroll height, or remove cookie warnings.
Value options:
"playwright:adaptive": string"playwright:firefox": string"playwright:chrome": string"cheerio": string"jsdom": string
Default value of this property is "playwright:firefox"
Include URLs (globs)
includeUrlGlobs
arrayOptional
Glob patterns matching URLs of pages that will be included in crawling.
Setting this option will disable the default Start URLs based scoping and will allow you to customize the crawling scope yourself. Note that this affects only links found on pages, but not Start URLs - if you want to crawl a page, make sure to specify its URL in the Start URLs field.
For example https://{store,docs}.example.com/**
lets the crawler to access all URLs starting with https://store.example.com/
or https://docs.example.com/
, and https://example.com/**/*\?*foo=*
allows the crawler to access all URLs that contain foo
query parameter with any value.
Learn more about globs and test them here.
Default value of this property is []
Exclude URLs (globs)
excludeUrlGlobs
arrayOptional
Glob patterns matching URLs of pages that will be excluded from crawling. Note that this affects only links found on pages, but not Start URLs, which are always crawled.
For example https://{store,docs}.example.com/**
excludes all URLs starting with https://store.example.com/
or https://docs.example.com/
, and https://example.com/**/*\?*foo=*
excludes all URLs that contain foo
query parameter with any value.
Learn more about globs and test them here.
Default value of this property is []
URL #fragments identify unique pages
keepUrlFragments
booleanOptional
Indicates that URL fragments (e.g. http://example.com#fragment
) should be included when checking whether a URL has already been visited or not. Typically, URL fragments are used for page navigation only and therefore they should be ignored, as they don't identify separate pages. However, some single-page websites use URL fragments to display different pages; in such a case, this option should be enabled.
Default value of this property is false
Ignore canonical URLs
ignoreCanonicalUrl
booleanOptional
If enabled, the Actor will ignore the canonical URL reported by the page, and use the actual URL instead. You can use this feature for websites that report invalid canonical URLs, which causes the Actor to skip those pages in results.
Default value of this property is false
Max crawling depth
maxCrawlDepth
integerOptional
The maximum number of links starting from the start URL that the crawler will recursively follow. The start URLs have depth 0
, the pages linked directly from the start URLs have depth 1
, and so on.
This setting is useful to prevent accidental crawler runaway. By setting it to 0
, the Actor will only crawl the Start URLs.
Default value of this property is 20
Max pages
maxCrawlPages
integerOptional
The maximum number pages to crawl. It includes the start URLs, pagination pages, pages with no content, etc. The crawler will automatically finish after reaching this number. This setting is useful to prevent accidental crawler runaway.
Default value of this property is 9999999
Initial concurrency
initialConcurrency
integerOptional
The initial number of web browsers or HTTP clients running in parallel. The system scales the concurrency up and down based on the current CPU and memory load. If the value is set to 0 (default), the Actor uses the default setting for the specific crawler type.
Note that if you set this value too high, the Actor will run out of memory and crash. If too low, it will be slow at start before it scales the concurrency up.
Default value of this property is 0
Max concurrency
maxConcurrency
integerOptional
The maximum number of web browsers or HTTP clients running in parallel. This setting is useful to avoid overloading the target websites and to avoid getting blocked.
Default value of this property is 200
Initial cookies
initialCookies
arrayOptional
Cookies that will be pre-set to all pages the scraper opens. This is useful for pages that require login. The value is expected to be a JSON array of objects with name
and value
properties. For example: [{"name": "cookieName", "value": "cookieValue"}]
.
You can use the EditThisCookie browser extension to copy browser cookies in this format, and paste it here.
Default value of this property is []
Proxy configuration
proxyConfiguration
objectRequired
Enables loading the websites from IP addresses in specific geographies and to circumvent blocking.
Default value of this property is {"useApifyProxy":true}
Maximum number of session rotations
maxSessionRotations
integerOptional
The maximum number of times the crawler will rotate the session (IP address + browser configuration) on anti-scraping measures like CAPTCHAs. If the crawler rotates the session more than this number and the page is still blocked, it will finish with an error.
Default value of this property is 10
Maximum number of retries on network / server errors
maxRequestRetries
integerOptional
The maximum number of times the crawler will retry the request on network, proxy or server errors. If the (n+1)-th request still fails, the crawler will mark this request as failed.
Default value of this property is 5
Request timeout
requestTimeoutSecs
integerOptional
Timeout in seconds for making the request and processing its response. Defaults to 60s.
Default value of this property is 60
Minimum file download speed
minFileDownloadSpeedKBps
integerOptional
The minimum viable file download speed in kilobytes per seconds. If the file download speed is lower than this value for a prolonged duration, the crawler will consider the file download as failing, abort it, and retry it again (up to "Maximum number of retries" times). This is useful to avoid your crawls being stuck on slow file downloads.
Default value of this property is 128
Wait for dynamic content
dynamicContentWaitSecs
integerOptional
The maximum time in seconds to wait for dynamic page content to load. By default, it is 10 seconds. The crawler will continue processing the page either if this time elapses, or if it detects the network became idle as there are no more requests for additional resources.
When using the Wait for selector option, the crawler will wait for the selector to appear for this amount of time. If the selector doesn't appear within this period, the request will fail and will be retried.
Note that this setting is ignored for the raw HTTP client, because it doesn't execute JavaScript or loads any dynamic resources. Similarly, if the value is set to 0
, the crawler doesn't wait for any dynamic to load and processes the HTML as provided on load.
Default value of this property is 10
Wait for selector
waitForSelector
stringOptional
If set, the crawler will wait for the specified CSS selector to appear in the page before proceeding with the content extraction. This is useful for pages for which the default content load recognition by idle network fails. Setting this option completely disables the default behavior, and the page will be processed only if the element specified by this selector appears. If the element doesn't appear within the Wait for dynamic content timeout, the request will fail and will be retried later. The value must be a valid CSS selector as accepted by the document.querySelectorAll()
function.
With the raw HTTP client, this option checks for the presence of the selector in the HTML content and throws an error if it's not found.
Default value of this property is ""
Maximum scroll height
maxScrollHeightPixels
integerOptional
The crawler will scroll down the page until all content is loaded (and network becomes idle), or until this maximum scrolling height is reached. Setting this value to 0
disables scrolling altogether.
Note that this setting is ignored for the raw HTTP client, because it doesn't execute JavaScript or loads any dynamic resources.
Default value of this property is 5000
Keep HTML elements (CSS selector)
keepElementsCssSelector
stringOptional
An optional CSS selector matching HTML elements that should be preserved in the DOM. If provided, all HTML elements which are not matching the CSS selectors or their descendants are removed from the DOM. This is useful to extract only relevant page content. The value must be a valid CSS selector as accepted by the document.querySelectorAll()
function.
This option runs before the HTML transformer
option. If you are missing content in the output despite using this option, try disabling the HTML transformer
.
Default value of this property is ""
Remove HTML elements (CSS selector)
removeElementsCssSelector
stringOptional
A CSS selector matching HTML elements that will be removed from the DOM, before converting it to text, Markdown, or saving as HTML. This is useful to skip irrelevant page content. The value must be a valid CSS selector as accepted by the document.querySelectorAll()
function.
By default, the Actor removes common navigation elements, headers, footers, modals, scripts, and inline image. You can disable the removal by setting this value to some non-existent CSS selector like dummy_keep_everything
.
Default value of this property is "nav, footer, script, style, noscript, svg, img[src^='data:'],\n[role=\"alert\"],\n[role=\"banner\"],\n[role=\"dialog\"],\n[role=\"alertdialog\"],\n[role=\"region\"][aria-label*=\"skip\" i],\n[aria-modal=\"true\"]"
Remove cookie warnings
removeCookieWarnings
booleanOptional
If enabled, the Actor will try to remove cookies consent dialogs or modals, using the I don't care about cookies browser extension, to improve the accuracy of the extracted text. Note that there is a small performance penalty if this feature is enabled.
This setting is ignored when using the raw HTTP crawler type.
Default value of this property is true
Expand iframe elements
expandIframes
booleanOptional
By default, the Actor will extract content from iframe
elements. If you want to specifically skip iframe
processing, disable this option. Works only for the playwright:firefox
crawler type.
Default value of this property is true
Expand clickable elements
clickElementsCssSelector
stringOptional
A CSS selector matching DOM elements that will be clicked. This is useful for expanding collapsed sections, in order to capture their text content. The value must be a valid CSS selector as accepted by the document.querySelectorAll()
function.
Default value of this property is "[aria-expanded=\"false\"]"
HTML transformer
htmlTransformer
EnumOptional
Specify how to transform the HTML to extract meaningful content without any extra fluff, like navigation or modals. The HTML transformation happens after removing and clicking the DOM elements.
-
Readable text with fallback - Extracts the main contents of the webpage, without navigation and other fluff while carefully checking the content integrality.
-
Readable text (default) - Extracts the main contents of the webpage, without navigation and other fluff.
-
Extractus - Uses Extractus library.
-
None - Only removes the HTML elements specified via 'Remove HTML elements' option.
You can examine output of all transformers by enabling the debug mode.
Value options:
"readableTextIfPossible": string"readableText": string"extractus": string"none": string
Default value of this property is "readableText"
Readable text extractor character threshold
readableTextCharThreshold
integerOptional
A configuration options for the "Readable text" HTML transformer. It contains the minimum number of characters an article must have in order to be considered relevant.
Default value of this property is 100
Remove duplicate text lines
aggressivePrune
booleanOptional
This is an experimental feature. If enabled, the crawler will prune content lines that are very similar to the ones already crawled on other pages, using the Count-Min Sketch algorithm. This is useful to strip repeating content in the scraped data like menus, headers, footers, etc. In some (not very likely) cases, it might remove relevant content from some pages.
Default value of this property is false
Debug mode (stores output of all HTML transformers)
debugMode
booleanOptional
If enabled, the Actor will store the output of all types of HTML transformers, including the ones that are not used by default, and it will also store the HTML to Key-value Store with a link. All this data is stored under the debug
field in the resulting Dataset.
Default value of this property is false
Debug log
debugLog
booleanOptional
If enabled, the actor log will include debug messages. Beware that this can be quite verbose.
Default value of this property is false
Save HTML to dataset (deprecated)
saveHtml
booleanOptional
If enabled, the crawler stores full transformed HTML of all pages found to the output dataset under the html
field. This option has been deprecated in favor of the saveHtmlAsFile
option, because the dataset records have a size of approximately 10MB and it's harder to review the HTML for debugging.
Default value of this property is false
Save HTML to key-value store
saveHtmlAsFile
booleanOptional
If enabled, the crawler stores full transformed HTML of all pages found to the default key-value store and saves links to the files as htmlUrl
field in the output dataset. Storing HTML in key-value store is preferred to storing it into the dataset with the saveHtml
option, because there's no size limit and it's easier for debugging as you can easily view the HTML.
Default value of this property is false
Save Markdown
saveMarkdown
booleanOptional
If enabled, the crawler converts the transformed HTML of all pages found to Markdown, and stores it under the markdown
field in the output dataset.
Default value of this property is true
Save files
saveFiles
booleanOptional
If enabled, the crawler downloads files linked from the web pages, as long as their URL has one of the following file extensions: PDF, DOC, DOCX, XLS, XLSX, and CSV. Note that unlike web pages, the files are downloaded regardless if they are under Start URLs or not. The files are stored to the default key-value store, and metadata about them to the output dataset, similarly as for web pages.
Default value of this property is false
Save screenshots (headless browser only)
saveScreenshots
booleanOptional
If enabled, the crawler stores a screenshot for each article page to the default key-value store. The link to the screenshot is stored under the screenshotUrl
field in the output dataset. It is useful for debugging, but reduces performance and increases storage costs.
Note that this feature only works with the playwright:firefox
crawler type.
Default value of this property is false
Max results
maxResults
integerOptional
The maximum number of resulting web pages to store. The crawler will automatically finish after reaching this number. This setting is useful to prevent accidental crawler runaway. If both Max pages and Max results are defined, then the crawler will finish when the first limit is reached. Note that the crawler skips pages with the canonical URL of a page that has already been crawled, hence it might crawl more pages than there are results.
Default value of this property is 9999999
Text extractor (deprecated)
textExtractor
stringOptional
Removed in favor of the htmlTransformer
option. Will be removed soon.
Actor Metrics
4.1k monthly users
-
854 stars
>99% runs succeeded
24 hours response time
Created in Mar 2023
Modified 13 hours ago