Booking.com Reviews Scraper
Pricing
from $1.30 / 1,000 results
Booking.com Reviews Scraper
[π° $1.3 / 1K] Extract guest reviews from any Booking.com property β full text, scores, languages, room types, stay dates, and partner replies. Pipe in URLs or pass the output of our Booking.com Scraper directly.
Pricing
from $1.30 / 1,000 results
Rating
0.0
(0)
Developer
SolidCode
Actor stats
0
Bookmarked
2
Total users
1
Monthly active users
3 days ago
Last modified
Categories
Share
Pull every guest review from any Booking.com property at scale β full review text, headlines, 0β10 scores, traveler segments, room types, stay dates, partner replies, and guest-uploaded photos β straight into a clean dataset, one review per row. Pipe in raw property URLs OR drop in the entire output of our Booking.com Hotel Scraper and start collecting reviews on the same run. Built for hospitality competitive-analysts, market-research firms, hotel-investment due-diligence teams, and SaaS reputation tools that need fresh, structured Booking.com review data without wrestling with rotating filters, multilingual pagination, and embedded reply threads.
Why This Scraper?
- $1.30 per 1,000 reviews β flat PPR. No compute charges, no per-property surcharge, no enrichment upcharges. One row = one review = one charge.
- Native pipe from the Booking.com Hotel Scraper β paste the upstream actor's dataset rows directly into
startUrls. Any object with aurlkey is auto-detected; every other field is ignored. No glue script, no manual URL extraction. - Five-axis filtering on Booking's native facets β 5 sort orders (Most Relevant, Newest, Oldest, Score High-to-Low, Score Low-to-High), 6 score buckets (Wonderful 9β10, Good 7β9, Okay 5β7, Poor 3β5, Very Poor 1β3, plus All), 26 review languages, 6 traveler segments (Families, Couples, Solo, Groups of Friends, Business, plus All), and 5 seasonal stay windows (MarβMay, JunβAug, SepβNov, DecβFeb, plus Any time of year).
- 30 fields per review row β review headline, "Liked"/"Disliked" body, 0β10 score, helpful-vote count, language code, traveler segment, anonymous flag, guest display name, guest country (ISO-2 + display name), avatar URL, room-type ID + name, nights stayed, stay status, check-in / check-out month, hotel reply text, hotel reply date, photo array (
{ id, urls.thumbnail, urls.large, kind }), Booking review ID, and a deep-linkreviewUrlanchored to the review on the property page. - 26 review languages, individually selectable β English, German, French, Spanish, Italian, Dutch, Portuguese, Polish, Russian, Japanese, Korean, Chinese, Arabic, Turkish, Swedish, Norwegian, Danish, Finnish, Czech, Hungarian, Romanian, Greek, Hebrew, Thai, Vietnamese, Indonesian. Multi-select for cross-market sentiment work; leave empty to collect every language.
- Partner reply capture, free β toggle
Include Hotel Replieson (default) and every row carries the property's officialpartnerReplyText. Critical for reputation-management SaaS measuring response rate, response speed, and tone across a portfolio. - Guest-uploaded photos in every row β Booking exposes original-resolution
largeandthumbnailURLs; both come back as aphotosarray per review for hotel-amenity computer-vision pipelines. - Predictable cost ceiling per property β
Max Reviews Per Propertydefaults to 1,000 (worst case $1.30 per property), with0opting in to "all available". Booking mega-properties can carry 10,000+ reviews; the cap stops cost runaways before they happen. - Tolerant input parsing β handles plain URL strings, bare
{ "url": "..." }objects, and full upstream dataset rows with extra fields. Rows whereurlis missing or null are quietly skipped instead of crashing the run.
Use Cases
Hospitality Market Research
- Benchmark guest sentiment across an entire city's 4-star inventory.
- Compare review-language mix to validate which markets a property is winning.
- Quantify month-over-month review velocity and average score for a competitor set.
Reputation Management & Hotel SaaS
- Power dashboards that surface fresh negative reviews to ops teams within hours.
- Audit a chain's partner-reply coverage β measure response rate, lag, and tone.
- Feed verbatim "Liked" and "Disliked" text into NLS / topic-modeling pipelines.
Investment Due-Diligence
- Pull 10 years of reviews on an acquisition target to validate brand health.
- Detect renovation impact: split scores by check-in date, before vs after a known refurbishment window.
- Surface the top recurring complaints driving sub-7 scores in a target portfolio.
OTA & Meta-search Aggregation
- Refresh reviews nightly across a curated catalog of 10,000+ hotels.
- Augment an in-house listings index with multilingual review snippets.
- Cross-check Booking review counts against TripAdvisor / Google for inventory parity.
Trend & Sentiment Monitoring
- Track sentiment by season β compare summer vs winter review tone in seasonal markets.
- Compare solo-traveler vs family vs business guest segments on the same property.
- Monitor a single hotel's score distribution week-over-week to flag service drift.
Travel Editorial & Content
- Generate "What guests really say about Le Meurice" articles from verified Booking text.
- Curate "Top 25 family-friendly hotels in Lisbon" lists from filtered review datasets.
- Pull guest photos to enrich hotel review write-ups with real-stay imagery.
Getting Started
1. Minimal β one property, all defaults
Returns up to 1,000 most-relevant reviews from a single property, every language, every traveler type, every score, every season. Hotel replies are included.
{"startUrls": [{ "url": "https://www.booking.com/hotel/fr/le-meurice.en-gb.html" }]}
2. Mid β newest negative reviews only
Triage the 100 most recent low-scoring reviews to find emerging service issues. Useful for ops dashboards and reputation alerts.
{"startUrls": [{ "url": "https://www.booking.com/hotel/gb/the-savoy.en-gb.html" }],"sortBy": "newest","scoreFilter": "poor","maxReviewsPerProperty": 100}
3. Advanced β pipe the Hotel Scraper output, then narrow by language and traveler
Run the Booking.com Hotel Scraper over a destination first, then drop its dataset rows straight into this actor's startUrls. The url key on each row is read; every other field (rating, price, address, etc.) is ignored. Below, only English-speaking solo-traveler reviews are collected, capped at 200 per property.
{"startUrls": [{ "url": "https://www.booking.com/hotel/gb/the-savoy.en-gb.html", "name": "The Savoy", "rating": 9.2 },{ "url": "https://www.booking.com/hotel/fr/le-meurice.en-gb.html", "name": "Hotel Le Meurice", "rating": 9.0 },{ "url": "https://www.booking.com/hotel/it/danieli.en-gb.html", "name": "Hotel Danieli", "rating": 8.9 }],"languages": ["en"],"customerType": "solo","maxReviewsPerProperty": 200,"includeReplies": true}
Input Reference
Property URLs
| Parameter | Type | Default | Description |
|---|---|---|---|
startUrls | array | [ "https://www.booking.com/hotel/fr/le-meurice.en-gb.html" ] | Booking.com property URLs to scrape reviews from. Accepts plain URL strings, bare { "url": "..." } objects, OR rows from another actor's dataset (any object with a url key β every other field is ignored). |
Pagination & Limits
| Parameter | Type | Default | Description |
|---|---|---|---|
maxReviewsPerProperty | integer | 1000 | Cap on reviews collected per property. Set to 0 to pull every available review (popular hotels can carry several thousand). Pricing is per review row, so this is your main cost lever. |
Sorting & Filtering
| Parameter | Type | Default | Description |
|---|---|---|---|
sortBy | string | relevant | How Booking.com orders reviews before collection. Options: Most Relevant, Newest first, Oldest first, Highest score first, Lowest score first. |
scoreFilter | string | all | Limit to one Booking score bucket. Options: All, Wonderful (9β10), Good (7β9), Okay (5β7), Poor (3β5), Very poor (1β3). |
languages | array | [] (all) | Multi-select review languages. Choose any subset of: English, German, French, Spanish, Italian, Dutch, Portuguese, Polish, Russian, Japanese, Korean, Chinese, Arabic, Turkish, Swedish, Norwegian, Danish, Finnish, Czech, Hungarian, Romanian, Greek, Hebrew, Thai, Vietnamese, Indonesian. |
customerType | string | all | Filter by traveler segment. Options: All travelers, Families, Couples, Solo travelers, Groups of friends, Business travelers. |
timeOfYear | string | all | Filter by stay season. Options: Any time of year, March β May (spring), June β August (summer), September β November (fall), December β February (winter). |
Output Options
| Parameter | Type | Default | Description |
|---|---|---|---|
includeReplies | boolean | true | Attach the property's official reply text to each review when available. Adds partnerReplyText and partnerReplyDate at no extra cost. |
Output
One row per review, flat schema for clean dataset table display.
Example
{"hotelUrl": "https://www.booking.com/hotel/fr/le-meurice.en-gb.html","hotelId": 55361,"hotelName": "Hotel Le Meurice","hotelCountryCode": "fr","reviewId": "6340bcc03d6b080b","reviewUrl": "https://www.booking.com/hotel/fr/le-meurice.en-gb.html#tab-reviews?review=6340bcc03d6b080b","reviewDate": "2026-04-18T15:17:40Z","title": "Excellent value for your money","positiveText": "Location is great, the staff were extremely helpful and the room was spotless.","negativeText": "There aren't any negatives for me staying here.","score": 10.0,"language": "en","helpfulVotesCount": 4,"isApproved": true,"customerType": "solo","anonymous": false,"guestName": "Carollyn","guestCountryCode": "us","guestCountryName": "United States","avatarUrl": "https://q-xx.bstatic.com/xdata/avatars/...","roomTypeId": "5536114","roomTypeName": "Standard Double Room","numNights": 2,"stayStatus": "stayed","checkInDate": "2026-04-12","checkOutDate": "2026-04-14","partnerReplyText": "Thank you for your wonderful review, Carollyn β we look forward to welcoming you back to Le Meurice.","partnerReplyDate": null,"photos": [{"id": "12345678","urls": {"thumbnail": "https://q-xx.bstatic.com/xdata/images/xphoto/square80/12345678.jpg","large": "https://q-xx.bstatic.com/xdata/images/xphoto/max1280x900/12345678.jpg"},"kind": "guest"}],"scrapedAt": "2026-05-01T19:16:14Z"}
Hotel Context Fields
| Field | Type | Description |
|---|---|---|
hotelUrl | string | Canonical property URL the review belongs to. |
hotelId | integer | Booking.com internal property ID. |
hotelName | string | Hotel display name. |
hotelCountryCode | string | ISO-2 country code (e.g. fr, gb, it). |
Core Review Fields
| Field | Type | Description |
|---|---|---|
reviewId | string | Booking-side review identifier. Stable across runs. |
reviewUrl | string | Deep-link to the review anchored on the property page. |
reviewDate | string (ISO 8601) | When the review was submitted to Booking. |
title | string | Review headline written by the guest. |
positiveText | string | "Liked" body. |
negativeText | string | "Disliked" body. |
score | number (0β10) | Reviewer's overall score for the stay. |
language | string | ISO-2 language code of the review text (en, de, fr, ...). xu indicates a short / unclassified review (Booking's own taxonomy). |
helpfulVotesCount | integer | Number of "Helpful" upvotes. |
isApproved | boolean | Booking-side moderation flag. |
Guest Fields
| Field | Type | Description |
|---|---|---|
customerType | string | families, couples, solo, groups, or business. |
anonymous | boolean | Whether the guest chose to remain anonymous. |
guestName | string | Display name (or Anonymous when anonymous=true). |
guestCountryCode | string | Reviewer's home-country ISO-2 code. |
guestCountryName | string | Reviewer's home-country display name. |
avatarUrl | string | null | Reviewer avatar URL when public. |
Stay Fields
| Field | Type | Description |
|---|---|---|
roomTypeId | string | Booking room-type ID for the booked stay. |
roomTypeName | string | Human-readable room type (e.g. "Deluxe Double Room"). |
numNights | integer | Length of stay in nights. |
stayStatus | string | stayed, cancelled, etc. (Booking taxonomy). |
checkInDate | string (YYYY-MM-DD) | Date the guest checked in. |
checkOutDate | string (YYYY-MM-DD) | Date the guest checked out. |
Hotel Reply, Photos & Metadata
| Field | Type | Description |
|---|---|---|
partnerReplyText | string | null | Hotel's official response to the review when present. null if no reply or includeReplies=false. |
partnerReplyDate | string | null | Reply timestamp when surfaced by Booking. |
photos | array of { id, urls: { thumbnail, large }, kind } | Guest-uploaded photos. Empty array when none. |
scrapedAt | string (ISO 8601) | UTC timestamp of extraction. |
Tips for Best Results
- Pipe the Booking.com Hotel Scraper output here directly. Run a destination + filter search in the Hotel Scraper, then drop the output dataset URL straight into
startUrlsin this actor β every row'surlis read automatically; everything else is ignored. No glue script needed for end-to-end "destination β reviews" pipelines. - Use
sortBy=newestfor monitoring fresh reviews andsortBy=score_ascto triage worst-rated reviews first when running a reputation-management dashboard. - For multi-language sentiment work, run separate jobs per language and join on
reviewId. This keeps each dataset narrowly scoped and avoids paying for languages you won't analyze. - Cap
maxReviewsPerPropertyat 1,000 unless you genuinely need every review. Mega-properties on Booking can carry 10,000+ reviews β at $1.30 per 1,000 that's $13 per property if uncapped. The default 1,000 keeps spend predictable. - Combine
scoreFilter=very_poorwithcustomerType=businessto surface the highest-impact complaints from corporate guests β these reviews often drive the biggest churn risk for hotel sales teams. - The
language=xuvalue is real, not a bug. Booking marks short reviews and reviews with no detectable language asxu. Keep them or filter them downstream β the actor returns the value verbatim. partnerReplyDateis permanentlynull. Booking does not surface the reply timestamp through its review feed; only the reply text is exposed. The field is kept on every row for schema stability.
Pricing
$1.30 per 1,000 reviews β flat per-result price.
No compute charges β you only pay per review returned.
| Reviews | Cost |
|---|---|
| 100 | $0.13 |
| 1,000 | $1.30 |
| 10,000 | $13.00 |
| 100,000 | $130.00 |
One dataset row = one review = one charge. Use maxReviewsPerProperty and the scoreFilter / languages / customerType / timeOfYear filters to control row volume before the run starts.
Integrations
Export data in JSON, CSV, Excel, XML, or RSS. Connect to 1,500+ apps via:
- Zapier / Make / n8n β Workflow automation
- Google Sheets β Direct spreadsheet export
- Slack / Email β Notifications when new reviews land
- Webhooks β Trigger custom APIs on run completion
- Apify API β Full programmatic access from any language
Legal & Ethical Use
This actor is designed for legitimate market research, hospitality intelligence, reputation management, investment analysis, and travel content creation. It collects only publicly visible review content from Booking.com property pages. Users are responsible for complying with applicable laws β including data-protection regimes that govern personal information in guest names and avatars β and with Booking.com's Terms of Service. Do not use the data to harass individuals, build replica review platforms, generate spam, or for any unlawful purpose.