Booking.com Reviews Scraper avatar

Booking.com Reviews Scraper

Pricing

from $1.30 / 1,000 results

Go to Apify Store
Booking.com Reviews Scraper

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

SolidCode

Maintained by Community

Actor stats

0

Bookmarked

2

Total users

1

Monthly active users

3 days ago

Last modified

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 a url key 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-link reviewUrl anchored 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 Replies on (default) and every row carries the property's official partnerReplyText. 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 large and thumbnail URLs; both come back as a photos array per review for hotel-amenity computer-vision pipelines.
  • Predictable cost ceiling per property β€” Max Reviews Per Property defaults to 1,000 (worst case $1.30 per property), with 0 opting 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 where url is 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

ParameterTypeDefaultDescription
startUrlsarray[ "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

ParameterTypeDefaultDescription
maxReviewsPerPropertyinteger1000Cap 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

ParameterTypeDefaultDescription
sortBystringrelevantHow Booking.com orders reviews before collection. Options: Most Relevant, Newest first, Oldest first, Highest score first, Lowest score first.
scoreFilterstringallLimit to one Booking score bucket. Options: All, Wonderful (9–10), Good (7–9), Okay (5–7), Poor (3–5), Very poor (1–3).
languagesarray[] (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.
customerTypestringallFilter by traveler segment. Options: All travelers, Families, Couples, Solo travelers, Groups of friends, Business travelers.
timeOfYearstringallFilter by stay season. Options: Any time of year, March – May (spring), June – August (summer), September – November (fall), December – February (winter).

Output Options

ParameterTypeDefaultDescription
includeRepliesbooleantrueAttach 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

FieldTypeDescription
hotelUrlstringCanonical property URL the review belongs to.
hotelIdintegerBooking.com internal property ID.
hotelNamestringHotel display name.
hotelCountryCodestringISO-2 country code (e.g. fr, gb, it).

Core Review Fields

FieldTypeDescription
reviewIdstringBooking-side review identifier. Stable across runs.
reviewUrlstringDeep-link to the review anchored on the property page.
reviewDatestring (ISO 8601)When the review was submitted to Booking.
titlestringReview headline written by the guest.
positiveTextstring"Liked" body.
negativeTextstring"Disliked" body.
scorenumber (0–10)Reviewer's overall score for the stay.
languagestringISO-2 language code of the review text (en, de, fr, ...). xu indicates a short / unclassified review (Booking's own taxonomy).
helpfulVotesCountintegerNumber of "Helpful" upvotes.
isApprovedbooleanBooking-side moderation flag.

Guest Fields

FieldTypeDescription
customerTypestringfamilies, couples, solo, groups, or business.
anonymousbooleanWhether the guest chose to remain anonymous.
guestNamestringDisplay name (or Anonymous when anonymous=true).
guestCountryCodestringReviewer's home-country ISO-2 code.
guestCountryNamestringReviewer's home-country display name.
avatarUrlstring | nullReviewer avatar URL when public.

Stay Fields

FieldTypeDescription
roomTypeIdstringBooking room-type ID for the booked stay.
roomTypeNamestringHuman-readable room type (e.g. "Deluxe Double Room").
numNightsintegerLength of stay in nights.
stayStatusstringstayed, cancelled, etc. (Booking taxonomy).
checkInDatestring (YYYY-MM-DD)Date the guest checked in.
checkOutDatestring (YYYY-MM-DD)Date the guest checked out.

Hotel Reply, Photos & Metadata

FieldTypeDescription
partnerReplyTextstring | nullHotel's official response to the review when present. null if no reply or includeReplies=false.
partnerReplyDatestring | nullReply timestamp when surfaced by Booking.
photosarray of { id, urls: { thumbnail, large }, kind }Guest-uploaded photos. Empty array when none.
scrapedAtstring (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 startUrls in this actor β€” every row's url is read automatically; everything else is ignored. No glue script needed for end-to-end "destination β†’ reviews" pipelines.
  • Use sortBy=newest for monitoring fresh reviews and sortBy=score_asc to 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 maxReviewsPerProperty at 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_poor with customerType=business to surface the highest-impact complaints from corporate guests β€” these reviews often drive the biggest churn risk for hotel sales teams.
  • The language=xu value is real, not a bug. Booking marks short reviews and reviews with no detectable language as xu. Keep them or filter them downstream β€” the actor returns the value verbatim.
  • partnerReplyDate is permanently null. 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.

ReviewsCost
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

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.