Booking.com Hotel Scraper - Prices, Reviews & Availability avatar

Booking.com Hotel Scraper - Prices, Reviews & Availability

Pricing

from $8.00 / 1,000 hotel scrapeds

Go to Apify Store
Booking.com Hotel Scraper - Prices, Reviews & Availability

Booking.com Hotel Scraper - Prices, Reviews & Availability

Collect public Booking.com hotel and accommodation listing data including prices, ratings, review counts, cancellation options, amenities, and property URLs.

Pricing

from $8.00 / 1,000 hotel scrapeds

Rating

0.0

(0)

Developer

Md Jakaria Mirza

Md Jakaria Mirza

Maintained by Community

Actor stats

0

Bookmarked

3

Total users

2

Monthly active users

2 days ago

Last modified

Categories

Share

Scrape Booking.com hotel and accommodation search results for travel market research, price monitoring, and competitor analysis. The actor searches one or more destinations for a date range, extracts clean property records, deduplicates by Booking.com property ID, and saves the results to an Apify Dataset. Export to JSON, CSV, Excel, or HTML, or pull via the Apify API — no login and no API key required.

For the first run, start small: one destination, a one-night future date range, maxResults between 5 and 10, and the recommended residential proxy enabled.

Each clean hotel record is saved through the hotel-scraped pay-per-event flow, so output is only kept when the event charge is accepted. The actor skips incomplete cards that do not expose a property name and Booking.com hotel URL, so the dataset avoids empty placeholder rows.

Features

  • Multiple destinations in one run
  • Check-in and check-out date search
  • Adults, rooms, currency, review score, and property type inputs
  • Pagination up to 500 properties per destination
  • Residential proxy support for Apify cloud runs
  • Random delays, session pool, and retry handling
  • Null fallbacks for fields that Booking.com does not expose on every search card

Data Extracted

FieldDescription
propertyIdBooking.com hotel slug or property ID
hotelNameProperty name
propertyTypeHotel, apartment, hostel, villa, resort, B&B, or guest house when exposed
starRatingStar rating when exposed
guestReviewScoreGuest review score from 0 to 10
reviewCountNumber of reviews
totalPriceTotal stay price for the searched dates
pricePerNightCalculated or exposed nightly price
originalPriceOriginal price before discount when exposed
discountPercentageDiscount percentage when calculable
currencyRequested currency
breakfastIncludedBreakfast signal from the card
freeCancellationFree cancellation signal from the card
roomsAvailableRooms available when exposed
amenitiesAmenities/facilities exposed on the card
city / countryParsed from destination input
distanceFromCityCenterDistance text from Booking.com
addressAddress when exposed
propertyUrlClean direct Booking.com hotel URL
thumbnailImageUrlProperty thumbnail image URL
latitude / longitudeCoordinates when exposed
sustainabilityBadgeSustainability badge signal
geniusDiscountGenius discount signal
scrapedAtISO timestamp

Use Cases

  1. Hotel price monitoring across cities and dates
  2. Travel app and comparison-site data enrichment
  3. Hospitality competitor research
  4. Market research by review score, price, and destination
  5. Accommodation data collection for travel market research

Pricing and cost control

This Actor uses Apify Pay Per Event + platform usage pricing. You pay for clean hotel records saved to the dataset, and you also pay the Apify platform usage generated by the run, such as compute and residential proxy traffic.

EventPrice
apify-actor-start$0.001 / GB
hotel-scraped$0.008 per clean hotel record
1,000 hotels$8.00 + startup + platform usage
10,000 hotels$80.00 + startup + platform usage

Cost-control tips:

  • Start with one destination.
  • Use a one-night future date range for your first test.
  • Use maxResults between 5 and 10 for test runs.
  • Add minReviewScore such as 7 to keep results cleaner.
  • Keep residential proxy enabled for reliability, but remember proxy traffic is billed as platform usage.
  • Increase destinations and result limits only after a small run returns the expected data.

Input

FieldTypeRequiredDefaultDescription
destinationsarrayyes["London, United Kingdom"]One or more destinations to search. Use one destination for tests.
checkInstringyes2026-07-15Future check-in date in YYYY-MM-DD format.
checkOutstringyes2026-07-16Future check-out date in YYYY-MM-DD format. Must be after check-in.
adultsintegerno2Number of adults per room.
roomsintegerno1Number of rooms to search for.
propertyTypesarrayno[]Optional property type filters. Leave empty for all accommodation types.
minReviewScorenumberno7Only include properties with a guest review score at or above this threshold.
maxResultsintegerno5Maximum properties per destination. Use 5-10 for tests; up to 500.
currencystringnoUSDDisplay currency for prices.
proxyConfigurationobjectnoResidentialApify proxy settings. Residential recommended and billed as platform usage.

Input Example

{
"destinations": ["London, United Kingdom"],
"checkIn": "2026-07-15",
"checkOut": "2026-07-16",
"adults": 2,
"rooms": 1,
"minReviewScore": 7,
"maxResults": 5,
"currency": "USD",
"proxyConfiguration": {
"useApifyProxy": true,
"apifyProxyGroups": ["RESIDENTIAL"]
}
}

Important: Booking.com requires future dates. If you reuse this sample later, update checkIn and checkOut to future dates before running.

How to Scrape Booking.com Hotels (Step by Step)

  1. Click Try for free / Run.
  2. Enter one destination and future checkIn / checkOut dates.
  3. Set adults, rooms, currency, and a small maxResults.
  4. Optionally filter by propertyTypes and minReviewScore, then click Run.
  5. When the run finishes, export results to JSON, CSV, Excel, or HTML, or pull them via the Apify API.

Output dataset

The default Hotel Records dataset view is designed for quick export to CSV, Excel, JSON, or API workflows. It shows the most useful booking research fields first: destination, hotel name, stars, guest score, review count, total price, nightly price, currency, city/country, distance from city center, cancellation signal, property URL, property ID, and scraped timestamp. Extra fields such as property type, amenities, original price, images, and coordinates remain available in the full JSON output when Booking.com exposes them.

{
"propertyId": "royal-national",
"hotelName": "Royal National Hotel",
"propertyType": null,
"starRating": 3,
"guestReviewScore": 7.9,
"reviewCount": 19601,
"reviewCategories": {
"location": null,
"cleanliness": null,
"comfort": null,
"facilities": null
},
"city": "London",
"country": "United Kingdom",
"distanceFromCityCenter": "1.8 km from downtown",
"totalPrice": 261,
"pricePerNight": 261,
"currency": "USD",
"breakfastIncluded": false,
"freeCancellation": false,
"propertyUrl": "https://www.booking.com/hotel/gb/royal-national.html",
"thumbnailImageUrl": "https://cf.bstatic.com/xdata/images/hotel/square240/example.webp",
"destination": "London, United Kingdom",
"scrapedAt": "2026-06-21T12:43:43.000Z"
}

Technical Details

  • Runtime: Node.js 20 on apify/actor-node-playwright-chrome:20
  • Scraping engine: Crawlee PlaywrightCrawler
  • Proxy: Apify residential proxy recommended for cloud runs
  • Retry policy: 3 retries with blocked-request retry handling
  • Storage: Apify Dataset
  • Charge model: Actor.pushData(record, "hotel-scraped")

Notes

  • Booking.com can vary card fields by market, destination, availability, and experiment. Unavailable fields are returned as null.
  • The default Apify table view focuses on populated search-result fields and hides optional columns that are often unavailable on Booking.com cards. Raw JSON still includes those fields.
  • This actor collects search result card data, not every detail available on individual hotel detail pages.
  • Data is for research and business intelligence, not booking, legal, or financial advice.

Responsible Use

This Actor is intended for lawful collection of publicly available information only. Users are responsible for ensuring their use complies with the source website's terms, robots.txt, applicable privacy laws, including India's DPDP Act, and all local regulations.

Do not use this Actor to collect, store, sell, or misuse personal data without a lawful basis. The Actor author is not responsible for misuse by end users.